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أ . المقدمة 
يعتبر 00۴ من أحدث التقنيات البرمجية في الوقت الحاضر» وقد ظهر هذا المفهوم في منتقصف التمانينات بعد 
ظهور البرمجة المهيكلةء وتعتمد الفكرة الأساسية في هذه التقنية على بناء كائنات (أو عناصر) لها خصائص محددة 
قابلة للتغير وتقوم بالاستجابة لأحداث وفق صيغ يمكن برمجتها بما يلائم التطبيق» وأهم محور في هذه الفكرة هو أن 
تكون هذه الكائنات قابلة للاستخدام أكثر من مرة ومن قبل أكثر من مستفيد مما يسهل عملية البرمجة من جهة ويوحد 
خصائص البر امج والتطبيقات من جهة أخرى. 


ب . الکائنات ء)ecز0©b‏ 
هي أصغر وحدة في 00۴ والتي يكون لها كيان مستقل ولها خصائصها التي يمكن تغييرها وصيغ استجابة محددة 
وقابلة للبرمجة للأحداث. 


ج . الصنوف كعويو[€C‏ 
هي عبارة عن التعريف المرجعي للقوالب التي يتم بناء الكائنات منها وهذه الصنوف تمتاز بصفات تابتة تميزها عن 
بعضها البعض . 


د . الأحداث Events‏ 
هي عبارة عن فعاليات تحدث إما من قبل نظام التشغيل أو من قبل مستخدم الحاسبةء وهذا المفهوم هو من المفاهيم 
الأساسية في أنظمة التشغيل متعددة المهام "asks Operating Systems)‏ tiاMu)‏ ومنها نظام التشغيل 
6 » وكمثال على الأحداث هو عملية نقر زر الفأرة أو ضغط مفتاح معين في لوحة المفاتيح...الخ. 


4 .لصخ Methods‏ 
الصيغ أشبه ما تكون بالإجراءات في البرمجة المهيكلة (s٠إںلعءه۴۲)»‏ وهي عبارة عن الفعاليات التي تنفذ من قبل 
الحاسبة كاستجابة للأحداث التي تقع. 


و . الخصائص الأساسية للبرمجة بالكائنات الموجهة 
هناك خصائص أساسية للبرمجة بالكائنات الموجهة وهي كالآتي: 
اول . لتوار Inheritance‏ 
هو عبارة عن إمكانية التصنيف الفرعي من صنف رئيسي وبناء ما يسمى sءهاءطuاS‏ من كءها€ موجود 
مسبقاء وهذا يها طن؟ يتوارث كل الصفات والخصائص والصيغ التي يمتلكها ويه1٤‏ الأصلي (الأب)ء 
لذلك فإن أي تغيير في صفات وخصائص الأب سوف ينعكس على الأبناء (sمءئھ[طSu).‏ 
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صديق قيس عبد الرحمن الدوسري 


ثانا . تفر ء۶ Polymorphism‏ 
هو عبارة عن إمكانية وجود صيغ (كئل0طا6) والتي لها نفس الاسم ولكن بمحتويات معالجة مختلفة» 


Encapsulation gan . lû 
هو عبارة عن تضمين وإخفاء المعلومات عن كائن معين» مثل هيكل البيانات الداخلي للكائن. وعن طريق‎ 
الدمج يتم عزل تعقيد عمل الكائن عن بقية التطبيق» كمثال إذا أردنا أن نكتب عبارة عنوان («٥0نامة٣) على‎ 

كائن معين فلا يهمنا في هذه الحالة معرفة كيفية خزن سلسلة الحروف (ع,5)۲1) لهذه الكائن . 


ز . الكائنات Control Objects)‏ 
هي أصغر الوحدات البرمجية والتي لها خصائص وصيغ «Text Box «Command Buttons Jin‏ 


e 


ح . الكائنات (Container Objects) gl‏ 
هي عبارة عن كائنات يمكن أن تحتوي عل کائنات أخرى سواء كانت حاويات أو مسيطرات مثل ؟۶صإه۴» Gridء‏ 


ا 


ط . مفهوم الکائنات في ۷٣۴‏ 
في ۷7۴ الكائنات الحاوية والمسيطرة هي الكائنات التي يمكن درجها في التطبيق ويمكن التعامل معها من خلال 
الخصائص (ع٤۲٥م٥ء۴)ء‏ الأحداث (ء٤ع8۷)ء‏ الصيغj .(Methods)‏ 
قد يبدو لنا أن الكائنات والصنوف هما نفس الشيء إلا أن هذا الاتجاه من المفهوم هو خطأ لأنهما لا يعنيان الشيء 
نفسه. الصنف (كءه1٣)‏ يحتوي على معلومات عن كيفية ظهور وتصرف الكائن» أو بعبارة أخرى هو القالب الذي 
يصاغ منه الكائن. ولتقريب هذا المفهوم للأذهان نأخذ مثالا واقعيا فالمخطط الإلكتروني لجهاز الهماتف والتصميم 
الأساسي للجهاز من حيث أنه يمكن إجراء الاتصالات به ويمكن طلب الأرقام من خلاله يمكننا من اعتباره صنف 
ئ (أي أنه صنف الأجهزة الذي يمكننا من الاتصال بالآخرين من خلاله) ويمكن اعتبار جهاز هاتف معين هو 
أحد الكائنات المنتمي لهذا الصنف. وبصورة عامة فإن الصنف يحدد الخصائص الأساسية للكائنات. 
الكائن (٤ءءزط0)‏ له عدد من الصفات (أو الخصائص) المحددة» على سبيل المثال جهاز الهاتف له لون وحجم ويأخذ 
موقع محدد في الغرفة. 
الكائنات التي يتم إنشاؤها في ۷۴۴ أيضا لها خصائصها المحددة والتي تتحدد من خلال الصنف الذي ينتمي له هذا 
الكائن وهذه الخصائص يمكن تغيير ها وإعطائها قيم معينة إما أثناء وقت التصميم (ع1۳آ «ع1وم2) أو إشاء وقت 
التنفيذ (ع11 «80). والجدول )١- ١(‏ يبين عدد من الخصائص التي قد تمتلکھا کائنات ۷۴۲ . 
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ا تخدم والجدول (۲ )١-‏ يبين عدد من الأحداث في ۷۴۲ . 


وكاستجابة للأحداث يوجد هناك ما يسمى بالصيغ (كلهط)6) وهي عبارة عن عبارات برمجية معينة تنفذ عند 
وقوع الحدث» وهي شبيهة إلى حد ما بالإجراءات (sعںلعءهإ۴)‏ في ۴۴ العادية إلا أنها تختلف من حيث أنها 
مرتبطة بالكائن وتختلف أيضا في طريقة استدعائهاء وعلى العموم فإن الأحداث (ا8۷6) في ۷۴۴ تكون محددة 
ولا يمكن إضافة أحداث جديدة إلى التطبيق» إلا أنه من الممكن إنشاء صيغ (ئلهط)6) جديدة. والجدول (۳ )١-‏ 
ببین عدد من الصیغ في ۷۴۶ , 


الخاصبة الوصف 
0 | العبارة التي تظهر على الكائن 
Forecolor‏ ا 8 
Backcolor‏ لون الخلفية للكائن 
Left‏ إزاحة الكائن عن يسار الشاشة 
Top‏ إزاخة الكائن عن أعلى الشاشة 
۴6 “___ خاصية منطقية ( ۲۲٠۲‏ أو مءاه۴) يحدد ظهور الكائن في الشاشة 
4 / خاصية منطقية ( ۲٥‏ أو عاه۴) يحدد هل الكائن فعال أو غير فعال 
Font‏ أسم البنط لحروف الكائن 
الجد )٠١ ١‏ بعض الخصائص لکائنات ۷۶۴۶۴ 
الحدتث ا 
Click‏ نقر زر الفأرة الأيسر 
5 || المستخدم يختار الكائن إما بالنقر عليه أو عن طريق ط1۵ 
Lostfocus‏ المستخدم يختار كائن آخر غير الكائن الحالي 
الجدول (۲ )٠-‏ بعض الأحداث في ۷۴۴ 
الا لف 
Refresh‏ إعادة تنشيط الكائن لعكس التغيرات التي قد تكون حدثت 
56 | نقل الاختيار إلى كائن معين 


الجدول (۳ )١-‏ بعت غ في ۴ ۷F‏ 


(T۳ 
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۲ . تصميم قاعدة البیانات في ۷٣۶‏ 


في ۷۴۴ يتم استخدام قاعدة البیانات (41۸8465۴٤‏ لغرض تنظيم وربط الجداول ءعاطة1 والمناظر sسwع‏ ز۷ . 
وقاعدة البيانات في ۷۴۴ يقدم معمارية ترتيب البيانات بالإضافة إلى ميزات أخرى تتضمن قواعد إدخال وتحديث 
القيود في الجداولء إعطاء الحقول قيم أولية ثابتةء التحقق من قيم القيود عند الإدخال أو التحدیث (۲۶٥عع!۲٣٣)ء‏ إنشاء 
الإجراءات (ك٥إduعءه٠إ۴)‏ لكل جدول» إنشاء علاقات تابتة ورصينة بين جداول قاعدة البيانات دون الحاجة إلى بناء 
هذه العلاقات أثناء التنفيذء بالإضافة إلى إمكانية إنشاء ء۷1 محلية أو بعيدة للبيانات والجداول ضمن القاعدة. 


ع 


أ . إنشاء قاعدة البيانات 


بعد تصميم قاعدة البيانات» من الممكن إنشاء القاعدة إما عن طريق واجهة المستخدم (٤٥۴۵إع)ہ!‏ إمءل) أو عن 
طريق البرمجة (كتابة إيعاز الإنشاء)ء وبعد ذلك يمكن تحديث محتويات قاعدة البيانات بالاسففادة من خاصية 
قاموس البيانات "2ry(‏ 10ا¡ )(ata‏ الموجودة في ۷۴۴ , 

عند إنشاء قاعدة البيانات يتم تجميع الجداول في حاوية واحدة للاستفادة من خاصية قاموس البيانات التي يمكن من 
خلالها إنشاء وتعريف ما يلي: - 

اولا . المفاتيح الأولية والمفاتيح المرشحة. 

ا اة دن اتحاول. 

ثالثا . الأسماء الطويلة للجداول والحقول. 

رابعا . عبارة العناوين (ك«هامه٣)‏ للحقول لإظهارها في نافذة #مءس8]0 وفي كلأا . 

خامسا . القيم البديهية لحقول. 

مادا 1 الف لبهي اللحفول فى شاقات :التمادج: 

سابعا . قواعد التحقق للحقول والقيود. 

ثامنا . خزن الإجراءات الخاصة بقاعدة البيانات . 

تاسعا . الهوامش والتعليقات للجداول والحقول. 


و لإنشاء قاعدة بيانات جديدة : 
نختار من ء۴ الاختيار سء ومن تم نختار عئ2طاه)ة( ونعطيه اسما فتظهر لنا الحاوية. 
uiتخدa CREATE DATABASE jl‏ . 
کمتال: - 
create database sample(or any other name)‏ 
ومن تم نکتب 


modify data [sample] (or any other name) 
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ب . التعا الجدا 
اولا . إنشاء جدول جديد في القاعدة 
يمكن إنشاء جدول جديد في القاعدة الحالية إما عن طريق الضغط على 1٥١‏ الإنشاء أو عن طرق النقر على الزر 
الأيمن للفأرة واختيار عااة1 سء" من قائمة الاختيارات التي سوف تظهر» وبصورة عامة فإن شاشة تصميم 
الجداول سوف تظهر كالآتي: - 


f Table Designer 


SEES 


ا 


)۲١ ۲( الشكل‎ 
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تانيا . إضافه جدول موجود مسبقا إلى قاعدة البيانات 
عند اختيار ۸١0ء1‏ الخاص بهذه الفعالية يظهر صندوق محادتة ×80 ع٥11(‏ الخاص بنظام التشغيل لاختيار 
الجدول الموجود في مكان معين من القرص ويتم إضافته إلى قاعدة البيانات. 


صديق قيس عبد الرحمن الدوسري 


عند استخدام إيعاز اط1 ۵ء۲٥‏ يتم إدراج أسم الجدول ضمن الإيعاز لغرض خزن الجدول بهذا الاسم. 
أسم الجدول يمكن أن يتألف من أحرف» أرقام» وعلامة التسجيل التحتية (esإ0ءءإملمن)‏ ويجب أن تبتدأً 
بحرف Îڇ .underscore‏ 


وفي حالة كون الجدول ضمن قاعدة البيانات فمن الممكن إعطاء الجدول أسم طويل يصل إلى حد ۱۲۸ رمز. 


ابعا . تغيير أسم الجد 
يمكن تغيير أسم الجدول من خلال واجهة تصميم قاعدة البيانات فقط (الشكل ۲ )١-‏ وذلك لأن المطلوب 
تغييره هو الاسم الطويل للجدول» ولتغيير أسم الجدول في قاعدة البيانات نتبع الخطوات التالية: - 
* في واجهة تصميم قاعدة البيانات (إء”ع1وم عء4طهاه() نختار الجدول المطلوب تغيير اسمه. 
* من قائمة eءaطa†ه2‏ نختار رنلفه. أو عن طريق نقر الزر الأيمن للفأرة على الجدول المطلوب 
لاستعراض قائمة العمليات على الجدول ونختار Modify‏ . 
* في شاشة مصمم الجدول إع,عاوم( ماطه1 نطبع سم الجدول في حقJ Table jaض Table Name‏ 
.t‏ (الشكل ۲ -۲) 


خامسا . حذف جدول من قاعدة البيانات 
هناك طريقتين لحذف الجدول من قاعدة البيانات: - 
#حذف الجدول من القاعدة دون حذفه بصورة نهائية من القرص ويسمى ٥1۱00۷ع۲.‏ 
#حذف الجدول من القاعدة ومن القرص ويسمى عع اع . 
ولحذف الجدول نتبع الخطوات التالية: - 
*من ٥۲‏ "عمل عءaطهtهل‏ نختار الجدول المراد حذفه» ومن قائمة عءaطه)ةل‏ نختار عاعاعل ضمن 
الاختيارات الثلاث التي سوف تظهر وهي 1عء١هء‏ ,عاعاعل ,٥00۷.ع۲,‏ وفي هذه الحالة سوف يحذف 
الجدول من القاعدة ومن القرص» أما عند اختيار ٠0۷”ع]‏ فإن الجدول يحذف من القاعدة فقط. 
أو 
* عن طريق نقر الزر الأيمن للفأرة (ءناء ٤1عذ)‏ على الجدول المراد حذفه فتظهر نفس الشاشة السابقة 
ذات الاختيارات الثلاث. 
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سادسا . تسمية الحة 
قواعد تسمية الحقول هي نفس قواعد تسمية الجداول. هذه الحقول يصل طولها إلى عشرة رموز في حالة 
عاط ععا؟ ويصل إلى ٠۲۸‏ رمز في حالة كون الجدول ضمن قاعدة البيانات. 
ولغرض تسمية الحقل يتم إدخال أسم الحقل في مربع عصه.× في إعمع1ءعل ماطهt‏ (الشكل ۲ .)١-‏ 


سابعا . اختيار نوع البيانات للحة 
عند إنشاء أي حقل يجب إدخال نوع البيانات الخاص بهذا الحقل والذي يحدد الخواص التالية: - 
* طبيعة القيم التي ستدخل في هذا (etc... «character, numeric) JaJ‏ 
* حجم الحقل (مساحة الخزن). 
* طبيعة العمليات التي يمكن إجرائها على الحقلء فمثلا يمکن جمع حتقJ currency وİ numeric‏ إلا إن 
هذا غير ممكن بالنسبة General yİ memo‏ . 
* إمكانية عمل فهرسة (×علم]) أو ترتيب (50۲۲) على الحقل تتدخل فيه أيضا نوعية بيانات هذا الحقل» 
فمثلا يمكن فهرسة حقل من نو ع ١عا٥12۲۵ء‏ ولا يمكن عمل فهرسة على حقل ۳0٣ع..‏ 


والجدول التالي بين أنواع البيانات في ۷۶۴۴: - 


Character j Any text EE EE Any characters 
to 254 
TYTTVY TIA EVV,oeA‘V “tO 
Currenc Monetary amounts Abytes 1 
urrency 33 A 7 


When using strict date formats 1-0-1} 
Date TT TT Abytes January 1st, 1 A.D to «<{۳1- ۱۲-4444 7^} December 
31st, 9999 A.D. 
٣ When using strict date formats 1-0-1} 
DateTime SS Abytes January 1st, 1 A.D to «<{۳1- ۱1۲-44447} December 
31st, 9999 A.D., plus 00:00:00 a.m. to 11:59:59 p.m. 


Logical Boolean value of true or false True (.T.) or False (.F(. 


Abytes in memory 
Numeric j Integers or fractions ۹4۹4۹4۹4۹4۹4444. - E+19 to .9999999999E+20 
EE \to 20 bytes in table 


-precisi ing- I114 ۷- - - 
Doubiê A double e floating Abytes oto 41۲ £= | HE-324 to +/ 
ڪڪ‎ poınt number 8.988465674311 5307 
Float Same as Numeric Abytes in memory; ۹۹4۹۹۹44۹۹4۹4۹44. - E+19 to .9999999999E+20 
1 to 20 bytes in table 


General Reference to an OLE object bytes in table Limited by available memory 


TV] 


٤ 


Reference to a block of data e in n table Timiell available DEO y 


Character Any character data you want to \ byte per character 
. maintain without change across Any characters 
(Binary ( code pages to 254 
Any memo field data you want 
. to maintain without change <bytes in table Limited by available memory 
(Binary ( across code pages 


ثامنا . إضافة فهرسة منتظnمة Adding Regular Index‏ 
عند إضافة أي حقل» يمكن إضافة فهرسة منتظمة ×ع ل1 إaاسعه‏ عليه من خلال تأشير المربع المسمى 
×عل10ء وهذه الفهرسة تكون إما تصاعدية أو تنازلية حسب مؤشر السهم. هذه الفهرسة سوف تضاف إلى 

فهرسة الجدول ويمكن تحديثه من خلال الضغط على ط14 ×ع لم[ في مصمم الجدوJ Table Designer‏ . 


تاسعا . استخدام قيم اللاشيء ءعu Null Va‏ 
عند إنشاء جدول جديد» يمكن تحديد حقل واحد أو أكثر ليتقبل القيم اللاشيء. عند استخدام ںاج۷ 11ں فإننا 
نثبت الحقيقة التي مفادها أن المعلومات المخزونة في هذا الحقل لقيود معينة غير محددة في الوقت الحاضر (أو 
عند إدخال القيد). وبدلا من استخدام صفر أو فراغ والتي قد تعني شيء ذو معنى يستخدم اانا" في قيمة هذا 
الحقل إلى أن تتاح المعلومة ذات المعنى. 
ولغرض إدخال 11ں لحقل معين» يتم تأشير مربع 11× لهذا الحقل بنقر زر الفأرة الأيسر عليه (تظهر 
علامة صح» وعند الضغط عليه مرة ثانية يختفي التأشير). ويجب ملاحظة أن الإيعاز اا" S۴۲‏ هو في 
حالة 0١‏ لكي يصبح كع ںاج۷ 11ں فعالا في جميع الجداول. 


عاشرا . إضافة التعليقات لحقول الجدول 
يمكن إضافة التعليقات لأي حقل في الجدول وذلك لجعل فهم الجدول سهلا بالنسبة لمصمم القاعدة أو بالنسبة 
لمطوري برامج القاعدة ومدير قاعدة البيانات» ويتم إضافة التعليقات من خلال مربع النص المسمى ]1ء۴ 
عص صت‌c‏ والذي يقع أسفل يمين شاشة مصمم lنجدJg Table Designer‏ . 


احد عشر . إنشاء القيم البديهية نفئحقJş Default Field Values‏ 
عندما نرید أن يقوم ۷۴۴ بإملاء قيم الحقل بصورة أوتوماتيكية عند إضافة قيد جديد إلى الجدول فإننا نستخدم 
Valve‏ ااDefau.‏ القيمة التي تدخل في الجدول تبقى فيه إلى أن يتم تغييره. (یمکن تحديید Default Value‏ 
لكل أنواع البيانات ما عدا اةإم”ع6). ولتحديد ماه ااسه؟ه لحقل معين يتم إدخال هذه القيمة في مربع 
(e fauاt Value‏ في المساحة المسماة Field Valid at‏ . قيمة Deut Values‏ تسر ع من عملية إدخال 
البيانات في التطبيق» حيث يتيح للمستخدم أن يعبر الحقل دون إدخال قيمة فيه (ما لم يريد أن يخزن فيه قيمة 
مختلفة)ء وهذه الحالة تكون مفيدة جدا خاصة إذا كانت هناك قواعد إدخال على مستوى القيد أو الحقل وهر ما 


1-۸] 


ڍسمy Default -level validation rules‏ يکن 


أن تكون أرقام أو تعبيرات حرفية أو حسابية أو منطقية وقد تكون عبارة عن دالة معرفة من المستخدم 105۴ . 


AalUES كيم‎ .ya1 atlon rules record-level ۾‎ Ile 


اثنا عشر . تحديد اع lلإıخJ Input Mask‏ 
عند استخدام هط ام1 فإننا نعرف صيغة الإدخال للقيمة البيانية (يتم ذلك من خلال تحديد الفواصل 
والفوارز والفراغات في صيغة الإدخال)ء ويتم هذا عن طريق إدخال الصيغة في مربع )ئه“" أامم! في 
المساحة المسماة رهامء51. 


هناك عدد من الخصائص التي تمكننا من السيطرة على أسلوب عرض الحقل سواء في كصإإه۴» 
Browse Window‏ أو في التقاریر . فیمکن تحدید صيغة العرض ۴٥۲۳ ۵٤(‏ رهامءi[)ء»‏ عنوان العرض 
.(Default Class) Jal زiصو «(Field Caption)‏ 

في المساحة المسماة رهآمءا يمكن تحديد صيغة العرض من خلال مربع ۴١۲۳02۲‏ وهي الصيغة التي 
تظهر فيها قيمة الحقل في جميع صيغ الإخراج في ۷۴۲۶ . 

ويمكن أيضا إدخال عنوان العرض من مربع ١٥10امة٥‏ في نفس المساحة»ء هذا العنوان سوف يظهر في 
Browse ۴0s‏ وفي التقارير بدلا من أسم الحقل في الجدول. 

ولاختصار الوقت عند تصميم النماذج (١طإ٥۴)»ء‏ يمكن تحديد sءها٣‏ هع( لكل حقل» ففي كل مرة 
يتم فيها إنشاء نموذج لهذا الجدول فإن 01إ٤«ه٣‏ ااسuه؟ع(‏ التابع إلى sیها€‏ ااسهfع(‏ المختار سوف يظهر 


في النموذج. 


Validation Rules jقحتلا اربعةعشر . قواعد‎ 

يمكن استخدام قواعد التحقق بأسلوبين وهما: - 1ع۷ع!1-ل1عا؟ و 1ع۷ع1-لإهءعع» وذلك للسيطرة على 
ت اة ف هارن اف كات قى هذه افراع الى من اة تة من الكفروط الى 
تتضمنها قواعد التحقق» فإذا كانت مستوفية للشروط فإن البيانات سوف تقبل وإلا فإنها سوف ترفض . وللعلمم 
فإن قواعد التحقق تكون متوفرة فقط في الجداول المقترنة ضمن قاعدة بيانات وغير متوفرة في الجداول الحرة. 
قواعد التحقق تختصر عملية كتابة هذه القواعد في اختيار ©۷411 في النماذج أو في المقاطع البرمجية في 
إيعازات البرنامج. 

كما ويمكن استخدام فهرسة الحقول من نوع إإة "إ۴ و ماه لiلمه٣‏ لمنع تكرار قيمة لحقل معين»ء وكذلك 
استخدام ١۲٥عع!1۲‏ لتوجيه ما يسمى بوجوب التكاملية (رااعءام] اهنارءإءfءR)‏ للقيام بفعاليات معينة عند 
تغيير البيانات في القاعدة» كل هذا يمكن إدراجه ضمن قواعد التحقق لجداول قاعدة البيانات. 
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يتم اختيار محددات قاعدة البيانات بالاعتماد على مستوى التحقق» وكذلك على العملية التي تجعل المحدد 
فعالا. يبين الجدول التالي محددات تحقق البیانات في ۷۶۴۴۴ : - 


Enforcement Mechanism Level Activated 
الفعالية المستوى ميكانيكية التو جيه‎ 
o When you move out of the field/column in a browse, or when the 
RO ON Field oF çOn field value changes during an INSERT or REPLACE. 
When you move out of the field/column in a browse, or when the 
Field-level rules Field or column field value changes during an INSERT or REPLACE. 


Record-level rules When the record update occurs. 


Cani When the record update occurs. 


VALID clause When you move off the record. 


4 When table values change during an INSERT’, UPDATE, or 
E 0 DELETE event. 


عقر تخ قق لحر من ق 
عندما نريد السيطرة على البيانات التي يتم إدخالها من قبل المستفيدء وإذا كنا نريد أن نتحقق من قيمة الحقل 
بغض النظر عن القيم في الحقول الأخرى نستخدم ۸٥0ا‏ :اva .fie1d-]eve1‏ 
و لإنشاء ١a)10ل‏ ااج 1ءvع14-1ء۴1‏ ندخل التعبير الخاص في مربع ءاuاR‏ في المساحة المسماة 4[ع۴ 


. Table Designer الموجودة في‎ validation area 

ولإضافة التعبير الذي يظهر أثناء حدوث خطاً معين ندخل التعبير في مربع عع2كءمM‏ في المساحة ]ء۴1 
„validation‏ 

۴۶ یتحقق من ءانا [1٥e۷ع[-1dع‏ ۴ عند تغییر قیمة الحقلء وھو على العکس من ٥۲۶‏ عع]إ1 فھو يتم التحقق 
منه حتى |ذ| Buffered Data aدختuږi iS‏ . 

وبالنسبة إلى ١0اةل‏ ناج۷ 1ع۷ع1-dإ0ءeعR‏ فهو يسيطر على نوع البيانات لقيد واحد» وذلك عن طريق عمل 
مقارنة بين قيم حقلين أو أكثرء فمثلا إذا أردنا أن نتحقق من كون قيمة أحد الحقول هو أكبر دائما من قيمة حقل 
آخر. ولإنشاء هذا النوع من التحقق ندخل التعبير وعبارة الخطاً في مربعي عاRu‏ و معةءيM6‏ في ماطa‏ 
Designer‏ في اختیار طھt‏ مھا (الشکل ۲ -۲). 


0 


لا تضع إيعاز أو Validation rules „ê Function‏ من التي تسبب تحريك مؤشر القید ( c0۲dءR‏ 
(Pointer‏ في مساحة العمل الحالية «Skip «Locate «Seek تIزjاڪq Jie «(Current Work Area)‏ 


14مم4) والتي قد تسبب حدوث نبضات متداخلة ٥۲۶‏ ع8٣1‏ ٥۷۲۷٠ء۲‏ مما يؤدي إلى حدوث خطأاً. 


۸-۰ [ 


یعرف ۲٥عع!1۲‏ على أنه التعبير الذي يرتبط بالجدول في قاعدة البيانات» ويتم استدعاء هذا التعبير كلما 
حدث تغيير في بيانات حقول الجدول. يتم إنشاء ١إ6عع1إ1‏ وخزنها بشكل خاصية من خواص الجدول داخل 


قاعدة البيانات» لذلك عند حذف الجدول من القاعدة تنتهي كء۲ععع1۲1 الخاصة بهذا الجدول بصورة نهائية. 
ویتمیز ٥۲۶‏ ع1۲1 عن باقي قواعد التحقق في أنه لا يستدعى عندما تكون البيانات في حالة Buffered‏ . 


لإنشاء ١إععع1۲1‏ يتم إدخال التعبير الخاص به ١10كئعإم×ءع‏ إعععآا) من خلال شاشة مصمم الجدول عإاطاةا 
Designer‏ من اختیار abe tab‏ (الشكل ۲ -۲( من خلاJ‏ lئمربڪھlٽ «Update trigger «Insert trigger‏ 
ڪ .Delete trigger‏ 

فمثلا إذا أردنا إنشاء إمعع1ع]) في نظام سيطرة على الخزين يقوم بإضافة حقل في جدول المواد (وليكن أسم 
الجدول sاءuلهإ۴)‏ وهذا الحقل أسمه (ليكن أ«سامصه_إءلإهء۲) يتم خزن كمية المادة المطلوب تجهيزها فيه 
عند وصول المادة إلى مستوى إعادة الطلب (وهو أيضا حقل ليكن أسمه 1٥۷٥[_إ٥أ۲١٠٠٠)‏ ويتم وضع حقلي 
رقم المادة (1d_اءuاكهإم)‏ وحقل كمية إعادة الطلب (٤٣uمصه_۲٥ل۲هع)‏ في جدول جديد (ليكن أسمه 
٣علاتعء)‏ للاستفادة من هذا الجدول في استخراج التقارير الخاصة بإعادة الطلب. هذا إعععاع) يتم استدعائه 
عند تثبيت صرف كمية من المادة للتحقق من وصول المادة إلى مستوى إعادة الطلب» هذا ٣عععا٣]‏ قد يكون 
بالصيغة التالية: - 


PROCEDURE updProductsTrigger 
IF (units_in_stock+units_ on_order) <= reorder level 
INSERT INTO Reorder VALUES(Products.product_id, ; 
Products.reorder amount) 
ENDIF 

ENDPROC 


ولحذف أو تحديث ١٥عع۲1)‏ موجود يتم الدخول إلى إ٥ععاا)‏ عن طريق مربعي 1ءgg!ا)‏ م )ءامل و 


. Table Designer ةشlژ ف„‎ update trigger 
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صديق قيس عبد الر من الدوسري 


. التعامل مع قاعدة البيانات في ۷۴۲ 


قاعدة البيانات توفر بيئة عمل يتم من خلالها إنشاء وخزن مجموعة من الجداولء ويوفر أيضا إمكانية إنشاء العلاقات 
(tionsh1psاeا)‏ بين الجداول» ويوفر بناء مجموعة من قواعد التحقق والسيطرة على البيانات. تخزن قاعدة البيانات في 
ملف له امتداد من نوع ( .٥ط4).‏ 


أ . فتح قاعدة بيانات 
يتم فتح قاعدة البيانات إما عن طريق اختيار قائمة ۴1٥‏ ومن ثم ١٥ص٠‏ واختيار قاعدة البيانات المراد فتحهاء 
أو عن طريق إيعاز عsوطa†ھd‏ nعمpە‏ كالآتى: - 
open database (database name) ٠‏ 


ب . تحديث محتويات قاعدة البيانات 
يتم الدخول في محتويات قاعدة البيانات لغرض التحديث عن طريق الإيعا 
modify database [database name]‏ 
ت¡ظqر‏ شlة database designer‏ 


ويبين الشكل (۳ )١-‏ مثال على قاعدة بيانات موجودة فيها عدد من الجداول المرتبطة بعلاقات مع بعضها 


Iê Database Designer - Testdata 


E oıditerma 
Ê Fields: 


Ba customer 
a F۴ ieldz: 


employee‏ ن 
a F leldz:‏ 


emp_id cust_id line_fıû 
lastk_narme company order_id 
firslk_name contact product_idl 
E title unik_price 
birth_date address quantity 


E Fields: Fields: 


order_id product_id cusk_id_a 
cust_id prad_narmêë campany 
emp_id enq_hamê contact 
to_name no_ir_ unit title 


to_address ¥ unit_price address 


Boxes display the fields and Relationship lines shou 
indexes in each table. joins between tables. 


الشكل (۳ )١-‏ مثال لقاعدة بيانات موجودة 


AT-] 


اا لار ل اا ی کی کر او 
يمكن من خلال استخدام 2طا0 معءهطه)ه( من معالجة جداول قاعدة البيانات والعلاقات بين الجداولء كما 
ويمكن إظهار كارع ااعا۲هطء عن طريق نقر الزر الأيمن للفأرة في مluحة Database Designer‏ . 
يمكن تغيير حجم الجداول في القاعدة لعرض حقول الجدول والفهارس على الحقول كما ويمكن توسيع عرض 
الجدول أو كبس الجدول أيضا. ولغرض توسيع عرض الجدول نضع موؤشر الفأرة على الجدول المطلوب ثم 
نضغط الزر الأيمن فتظهر قائمة نختار منها a1۵‏ م×8. أما إذا أردنا كبس عرض الجدول فإننا نختار 
.Collapse‏ 
أما إذا أردنا أن نوسع عرض كل الجداول أو نكبس عرض كل الجداول فإننا نضغط الزر الأيمن للفأرة في 
lwnحة .Collapse all yi Expand all رlتخig database designer‏ 


E Database Designer - Testdata EE Eî 


# ordilems 


BH employee "ê inyoire 


Collapse all tables in the database 


من الممكن أن نغير توزيع الجداول في Database Designer‏ أو أن نرتبها وفق صيغة معينة وذلك عن 
طريق اختيار عع ١ة۸۲۲‏ من قائمة عءةطاه)ه( فتظهر شاشة لغرض اختيار نوع الترتيب المطلوب وحسب 


Arrange the tables alphabetically by name 
Arrange the tables by type 

Align the tables in a row 

Align the tables in a column 
Return the tables to their original size 


لغرض خزن الملاحظات حول قاعدة البيانات نختار من قائمة عءaطهاهل‏ اختيار sعن)امممام‏ ونكتقب 
الملاحظات في مربع .٥0010۴1‏ 
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1 حامعة الانبار ا صديق قير عبد الرجر الدوسرى 


E 2 DD 
Table Indexinı سن الحذان‎ 


الغرض من فهرسة الجداول هو التعامل السريع مع البيانات المخزونة فيه وترتيب عرض هذه البيانات في 
التقارير والمخرجات» وللفهرسة أهمية أكبر في بناء العلاقات بين الجداول. 

يمكن إنشاء الفهارس على الحقول أو على تعبيرات» ولغرض إظهار أهمية الفهرسة يجب فهرسة الحقول التي 
يحصل عليها تصفية (6۲٤11؟)‏ أو استفسارات أو تستخدم في إنشاء المنظورات س۷1 أو في التقارير ويجب 
فهرسة الحقول التي تستخدم في إنشاء العلاقات بين الجداول. ولغرض إنشاء الفهارس نختار الجدول المطلوب 
فهرسته وندخل إلى شاشة ,وم2 1eط14‏ ونختار طهt‏ sم×ملہ1.‏ كما في الشکل (۳ -۲). 


Table Designer - customer .dbf 


Fields | Indexes | Table | 
Enter a name for 


the index here. 1 Aedar ame Type Expression Filler r =` Click here to enter a 
+ COMPANY Fegular cormpahy 8 condition for record 
lick here to sort in selection. 
: f  LUNTALT Regular contact 
ascending or Cancel | 
Hescending order. t PUSTSLLDODE Regular postalcode 
f LUST_ID Primary cusl_id 
Insert | 
EEF ÊV f  LUUNNTRY Regular WIPPERIcounl 
index here. E Glick here to delete 
2 e 


lick here to set an Glick here to enter ari 
index: type. index expression. 


الشكل (۳ )۲١‏ مثال لفهرسة جدول 
في مربع N4۳68‏ نطبع أسم الفهرس. 
في قائمة مما نختار نوع الفهرس المطلوب. 
في مربع ١10ءء٥۲م×E‏ نطبع أسم الحقل المراد عمل فهرسة عليه أوبناء تعبير عند طريق 
ضغط مربع المحادثة ×0ط اهال الموجود في النهاية !إ¡ۈlqر Expression Builder‏ , 
في حالة اختيار مجموعة من القيود (عمل ١1)6؟)‏ ندخل التعبير في مربع ۲ع)]۴. 
أخيرا نختار 0. لبناء الفهرسة على الجدول. 


" 


د . اختيار نوع الفهرسهةه 
من الممكن اختيار واحدة من أربعة أنواع من الفهارس (تظهر في قائمة ءمر٣)‏ وهذه الأنواع الأربعة هي 
کالائی:- 

Primary 
Candidate 


Regular 
Unique 


۸7-7٤ ( 


صدیق قيس ا ا 


اولا Py‏ = ين هذا اللو ارت رحن اا ا ا سا 
مجموعة من الحقول)ء وبعبارة أخرى فإن الحقل المفهرس رإة”1إ۴ هو الحقل المفتاحي للجدول» ويمكن 
عمل فهرسة واحدة فقط من هذا النوع لكل جدول ضمن قاعدة البيانات» وتظهر فهرسة الحقل على شكل 
Bod Fn‏ في الجدول للدلالة على aryص Pri‏ في ژlشة .Database Designer‏ 


ثانيا . Candidate 1nde×es‏ - هذا النو ع من الفهرسة يعطي أيضا إمكانية وحدانية القيمة المدخلة للحقل 
(أو الحقول) مثل رإة ۴۲ء ويمكن عمل أكثر من ×٥ل,1‏ من هذا النوع للجدول الواحد وتكون أيضا 
علی شکل ۴٥٤‏ 8014. وبعبارة أُخری فإن did 2e‏ م2٣‏ يعني أن هذا الحقل هو من الحقول المرشحة 
لأن تكون مفتاحية. 


ثالثا . sء×٥ءd«[‏ هاسع :R‏ - يحدد الترتيب الذي تظهر فيه القيود تبعا لقيمة حقل الفهرسة عند معالجة 
الجدول سواء في الإدخال أو الإخراج أو التعامل» ويمكن إدخال قيم مكررة في حقل (أو حقول) الفهرسةء 
ويمكن عمل عدة أنواع من الفهارس من هذا النوع. 

رابعا . nique 1nd e×es‏ - وضع هذا النوع من الفهرسة لعمل توافق (رأنازطنادمصدcء)‏ مع النسخ 
السابقة» ويستخدم هذا النوع لعمل فهرسة على حقول فيها تكرار لإظهار القيمة الأولى لكل تكرار قيم 
للبيانات فقط وفق شرط أو شروط محددة. 


Ê Fields. order id 3 
customer_id e1 Ra 
RR ahipper_id Because theze tables have 


cantact_name order_number this field in cornrman... 

contact title order_dale 

address ship_to_name 

ciky ship_to_address 

region zhip_to_city 

pustal_code ship_to_regior 

country ship_to_postal_code 

phone ship_to_country 

fa discount 

rmak_order_ arnt freight 

min_order_arnt deliyer_by 

discount notes 

zales_region employee_id 
LEllndeses: LEllndexes. 

company_ha shipper_id 
Tcustomer_i | ج‎ rııatomer i 


ermplopee_i 
order_ numb 

f order_id 

cusl_ord 


„YOu cah add indexes to support 
1 a relationship between the tables. 
¥ 


الشكل (۳ -۳) مثال على علاقة بين جدولين 


۸7-5 


جداول مع بعضها البعض 

يوفر €۲" عes1( Database‏ عملية ربط الجداول مع بعضها العض بصورة سهلة وذلك عن طريق ربط 
فهارس الجداول مع بعضها. هذه العلاقات (كمذطكمماهاه) التي يتم إنشاؤها في قاعدة البيانات يطلق عليها 
أسم العلاقات الثابتة (كمطومماهاءا tمعاءiإهم)‏ وذلك لأنها تخزن كجزء من قاعدة البيانات» وفي كل مرة 
يتم استخدام الجداول في النماذج والاستفسارات والمنظورات تظهر هذه العلاقات بصورة بديهية بين الجداول 
دون الحاجة إلى تكرارها عن طريق العبارات البرمجية. 

قبل أن ننشأً علاقة بين الجداول يجب أن تشترك الجداول مع بعضها في حقول وفهارس محددة. هذه الحقول 
تىمى Primary Key‏ و .۴0relgn Key‏ حقل yع۴K‏ ۴۲1۳۵۲۷ یعرف قید واحد محدد في جدول معین› 
بينما يعرف رع «ع1ءإه۴ القيود الموجودة في جدول آخر والتي تنتساوى في قيمھمامع .Pr1mary )ey‏ 
لذلك نحتاج عند عمل 101ځڃRel‏ بين جدولين jİ‏ 4ر Primary Index ةiٍaç Primary Key‏ 
فر .Regular Index ةغuصڊب Foreign Key‏ 

ویوضح الشکل (۳ -۳) مثال على علاقة بين جدولين وهما 0”0۴۲اءلاء و ؟إمل۲إ0» كل منهما يحتوي على 
عدد من الحقول حسب تصميم القاعدة» ويوضح الشكل الحقول في الجدولين التي لها نفس القيمة (علاقة ١‏ : 
۳ محددة في تصميم القاعدة في نموذج البيانات) هذان الحقلان هما ٥۲_14‏ 0اءاء في جدول ٣۴۲‏ 0ءء و 
customer_d‏ في جدول كءإعل۲ه (يمكن أن يحمل الحقلان أسمين مختلفين إلا أنه من الشرط أن يكونان 
بنفس نوع البيانات ونفس الحجم). ولغرض إنشاء علاقة بين الجدولين يجب أن تكون هناك فهرسة من نوع 
Primary‏ على حقل 8۲_14 10ء في جدول 0۳8۲ء على اعتبار أنه حقل مفتاحي في هذا الجدول 
»)Primary Key)‏ ویجب ان تكون هناك فهرسة على حقل ۳٥۲_114‏ 0ءء في جدول ١إعل]0‏ من نوع 
اع على اعتبار أنه حقل أجنبي (ره) «عذ٥۲ه۴)‏ في هذا الجدول. 

ويمكن بناء العلاقة بين الجدولين عن طريق تأشير «×1,"6 رع رإهصإ۴ في الجدول الأول وتحريك الفأرة 
دون رفع الضغط عن زر الفأرة (من الممكن عمل هذه العملية بضغط الزر الأيمن أو الأيسر للفأرة) ومن ثم 
تأشير ×eل"1‏ ر «عiءإه۴‏ في الجدول الثاني ومن ثم رفع الضغط عن زر الفأرةء فيتولد خط علاهة بين 
الجدولين يكون ذو طرف واحد من ناحية ×مل”1 Primary Key‏ وله ثلاثة تشعبات (للدلالة على yرصجM)‏ فى 


ناحية Foreign Keر 1nd e×‏ وبهذه الطريقة يتم إنشاء علاقة الواحد للتعدد (رمجص 0 عده). 


و . تحديث العلاقة 

بعد إنشاء العلاقة بين جدولين يمكن الدخول في تحديث العلاقة وبناء قواعد وجوب الوحدانية ) Referential‏ 
رااعها"!)» يتم ذلك عن طريق نقر خط العلاقة نقرتين مزدوجتين ()عناء ماطاسمل) بواسطة زر الفأرة 
الأيسر لتظهر الشاشة التالية: - 


۸-۹ 


م حجامعة الانبار- 


Table: customer Related table: orders 


| cust Id 1 | cusk_id 3 1 


Relationship pe: Une To Mary 
Referential Integrity... | إ‎ Lancel | Help | 


تظهر الشاشة أعلاه طبيعة العلاقة بين الجدولين (وهي تكون ع«ه-ها-ع١ه‏ إذا كانت فهرسة ۴۲٣۵۲۷‏ و 
Foreign‏ هما من نوع Primary)‏ أو )Candidate‏ وتكون العلاقة (رمجص-ها-عمه) إذا كانت فهرسة 
Primary‏ هي من نوع Primary)‏ أو )Candidate‏ وفهرسة ع۴01 هي من نو ع .)R‌egu[4۲(‏ 

ويمكن أيضا من خلال هذه الشاشة الدخول إلى وجوب التكاملية راإعما١!‏ a1٤ءإم؟Re‏ والتي من خلالما 
يتم اختيار قواعد الإدخال والتحديث والحذف تبعا للجدول الأب وتأثيره على الجدول الابن. 

عند الدخول في راآاعع)١[‏ اهن)ارءاءRe‏ تظهر شاشة فيها ثلاث sطاه)‏ وهي «rules for updating)‏ 
»rules for deleting‏ و f0r inserting‏ sعاuا)‏ كل واحدة منها تضع قواعد خاصة بعملها وكالآتي: - 

هذه القواعد هي : - 

* eل2ءءة):‏ - أي تغيير في قيمة المفتاح الأساسي (رإع5 رإة"1إ۴) في الجدول الأب سوف ينعكس على 
القيم المقابلة لها في الجدول الابنء أي أنه إذا تغيرت قيمة المفتاح الأساسي في الجدول الأب فإِن ۷۶۴۴۴ سوف 
يقوم بصورة أوتوماتيكية بتغيير القيم المقابلة في الجدول الابن إلى القيمة المحدثة. 

R6٤‏ - يمنع تحديث قيمة المفتاح الأساسي في الجدول الأب لذلك لا توجد قيود يتيمة في الجدول الابن. 

* n0۲ع1:‏ - وهي القيمة ااه؟ه وفيها يسمح بتغيير قيمة القيد في الجدول الأب n‏ كان هناك قيود 
مرتبطة معها في الجدول الابن (دون تغيير قيم الجدول الابن). 


ز . فتح أكثر من قاعدة بيانات 
دک یمک الات لے ف ی من ات اا رلت عن غريى كر ا ورن 
مه وفي هذه الحالة فإن آخر قاعدة تم فتحها تكون هي القاعدة الفعالة» ولغرض تحويل الفعالة إلى 
قاعدة أخرى مفتوحة (ولكنها غير فعالة) نستخدم إيعاز: - 


Set Database to (database name ) 


4 


- في ۷۲ قد نفتح أكثر من قاعدة بيانات وخاصة في الاستفسارات والنماذج» لذا يجب أولا استخدام 
ليعاز 70 ءsمطهاه2‏ ۲ء5 (...) قبل كتابة أي إيعاز آخر وذلك لضمان أننا نعمل مع القاعدة المطلوية. 


۸7-۷7 


جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدوسري 


ح . غلق قاعدة البيانات 
يمكن غلق قاعدة بيانات مفتوحة من خلال إيعاز: - 


Close database 
إذا كان لدينا أكثر من قاعدة بيانات مفتوحة لضمان أننا‎ )...( 561 هاهطaهءم‎ 1٠ والتي يجب أن يسبقها إيعاز‎ 
.۲٥ء)ل نغلق قاعدة البيانات المطلوب غلقها فعلا. ويوضح المثال أدناه هذه العملية لقاعدة بيانات تحت أسم 4ه‎ 


Set data to testdata 
Close database 


۸7-۸7 


حامعة الانبار - كلية الجحاسوب 


صديق قيس عبد الرحمن الدوسري 


تستخدم النماذج لإنشاء واجهات المستخدم التي تساعد العاملين على الأنظمة من إظهار البيانات وإدخالها إلى القاعدة 
بصورة سهلة وبكفاءة عالية. والحقيقة أن النماذج لها أفق أوسع من كونها واجهة عرض للمستخدم فقط وإنما يتعدى 
دورها إلى أنها عبارة عن حاوية تتضمن مجموعة من كائنات السيطرة (ءاءعزطا0 1١إ٤١٥))‏ والتي تستجيب وفق 
صيغ محددة من قبل مصمم النظام إلى الأحدات التي تصدر من النظام أو من مستخدم النظام والتي تساعد في إنجاز 
إدارة بيانات النظام بكفاءة وبسهولة. 
حیث یوفر ۷۴۴ مصمم نماذج ذو كفاءة عالية يسهل ويسرع عملية إنشاء النماذج» حيث يوفر لممصمم النموذج 
الإمكانيات التالية: - 

عدد كبير ومختلف من الكائنات في النموذج. 

ربط البيانات في الجداول مع الكائنات . 

النموذج الرئيسي والنماذج التابعة. 

إمكانية معالجة عدد من النماذج مع بعضها البعض . 

إمكانية استخدام قوالب تصميم من ۷۴۴ أو قوالب تصميم خاصة بالمصمم. 
النماذج (ئطإ٥۴)‏ ومجمو عة النماذج (6؟5 )۴٥۲۳‏ هي عبارة عن کائنات (Properties) lqaıصخ ll (Objects)‏ 
وأحداثها (s٤٠م8۷)‏ وأسلوب التعامل مع الحدث (كلهط) المستقلة والتي يمكن برمجتها وإعادة صياغتها وفقا 


الفص: 


أ . إنشاء نماذج جديدةö Creating New Forms‏ 
يمكن إنشاء نماذج جديدة بعدة طرق: - إما عن طریق مصمم النماذج (۴۲ہعذوB٥ )۴٥۲۳‏ أو قوالب 
التصميم yİ (Form Wizards)‏ عن طريق البرامج. 
یمکن إنشاء النماذ ج باستخدام ۴۲٬عاوDe٥ ۴٥۲۳‏ عن طریق اختیار ٥w‏ من قائمة ٥ا۴‏ ومن ثم اختيار 


.New File laدzڊy‎ Form 


۸7-۹ [ 


TRE‏ ب 
Forml HET E‏ 


YF Color Palette 


الشكل (؛ )٠-‏ مثال على نموذج فارغ مع أشرطة الأدوات (۵۲ط۵۱٣۲)‏ التي یمکن استخدامھا ( ۴٥٣٣‏ 


(Layout «Color «Form designer «Control 


النموذج هو عبارة عن حاوية يمكن إضافة ءاءعزطا0 من ءعءءها مختلفة فيه (عن طریق استخدام ۴٥۲۳‏ 
»)€ontr01 r oo1bar‏ ویمکن تغییر خصائص ھذہ ءاc‏ ٥زط0‏ عن طریق شاشة الخصائص ( ٤م٥٣۲‏ 
»)Win 0w‏ ويمكن ربط النموذج مع جداول البيانات من خلال بيئة البيانات „(Data Environment)‏ 


ب . التعامل مع بيئة بيانات lلgaiذ‏ چ Setting The Data Environment‏ 

کل ۴٥۲۳‏ أو ام؟ ۴٥۲۳‏ يحتوي على بيئة بيانات خاصة به. وبيئة البيانات للنموذج هو عبارة عن كائن 
يحتوي على الجداول والمنظورات التي یتعامل معھا .۴٥۲۳‏ ویکن تصمیم )۳0۴۸۲ ٥a)a En v1r0۸‏ بصورة 
مرئية ااج ںی۷ باستخدام مصمم بيئة lلبيllٽت Data Environment Designer‏ وخزنaە‏ مع 
النموذج. ویقوم 8۷1۲0۸۳۴۸۲ 41( بعملية فتح وغلق جداول البيانات بصورة أوتوماتيكية بالإضافة إلى 
المساعدة في تحديد مصدر السيطرة (ع Suc‏ 1٥إCont)‏ لكل كائن سيطرة (اecزbا0 )€n t01‏ في 
النهموذج من خلال التعامل مع خاصية S01٥٥‏ 1١إاره‏ الموجودة في نافذة الخصائص ( ۲۴٥p)‏ 
.(Windows‏ 

ولغرض التعامل مع (ata En vir٥۸ ٤1٤‏ التابع إلى ۴٥۲۳‏ مفتوح نختار من قائمة ع۷1 اختيار ٥a4‏ 
Environment‏ أو عن طريق نقر الزر الأيمن للفأرة لإظهار قائمة مختصرة نختار منها اختيار وج5 
Environment‏ . إذا تم اختيار قائمة سز۷ فسوف تظهر لنا شاشة محادثة باسم ١6ص0‏ نختار منها الجدول 
أو المنظور لإضافته إلى Data Environment‏ İو‏ یمکن فتح هذه الشاشة عن طريق نقر الزر الأيمن لإظهار 
قائمة نختار منها لل۸. 


۸-7۰7 


صديق قيس عبد الر حم الدوسري 


ا 


N HOWEE 


Form Designer 

: Properties 

Seep ia Lode... 
: Help... 


الشکل ٤(‏ ۲۰) مثال على (Data Envİا٥٣ ٣٤٣۸٤‏ لنموذچ مفتوح 


الجدول أدناه يبين عدد من الخصائص المشتركة لبيئة البيانات والتي يمكن التعامل معها من خلال نافذة 
الخصائص . 


efa ult Value‏ القيمة البديهية description‏ الوصف Property‏ الخاصية 
ASC ate ThE Controls whether tables and views are closed when the True (T(.‏ 
form is released.‏ ڇڪ و 


Controls whether tables and views in 


AutoOpenTables the data environment are opened when the Triüé (.T(. 


form is run. 


" "at design time. If not specified, at run 
time the first cursor added to the 


DataEnvironment is initially selected. 


Specifies the table or view that is selected when the 


InitialSelected Alias FoF i fû: 


ج . إضافة جدول أو منظور Data Environment Jd‏ 
عند إضافة eاطھ٦‏ أو View‏ إلى ata Environment‏ يمكن أيضا اختيار الحقول والفهارس التابعة إلى 
View yİ Table‏ . 
ولغرض إضافة 1eطھ٦‏ أو View‏ إلى Data Environment‏ نتبع الخطوات التالية: - 

من (ata Environment designer‏ نختار ۸04 من قائمة الاختيارات. 

من شاشة سع۷ إ0 م1ط14 4ل نختار الجدول أو المنظور المطلوب من القائمة التي تظهر في الشاشة. 


SERAN 


حامعة الانبار - كلية الحاسوب صديق قيس عبد الرحهمن الدوسري 
e‏ 
في حالة عدم فتح أي قاعدة بيانات أو في حالة الحاجة إلى استدعاء بيانات من خار ج القاعدة نختار ١إعط)ا©O‏ 
لاختيار مصادر البيانات من مكان آخر. 
في حالة کون Data Environ men)‏ فعالا تعرض شاش llخlÛأئغص (Properties Window)‏ 
الكائنات (ءاءعزطا0) والخصائص (ءع٤إعم٠ه۴۲)‏ المقترنة ببيئة البيانات. كل الجداول والمنظورات والعلاقات 
بل وحتى بيئة البيانات نفسها هي عبارة عن كائن مستقل يظهر في مربع كاععز0b‏ في Properties‏ 
Window‏ . 
د . حذف جدول من بيئة البيانات 
يمکن حذف 1eطa٣‏ من Data Environment‏ وكل العلاقات (مiطs«ەiاهاءا)‏ التي تربط هذا الجدول 
سوف تحذف معه. ولغرض حذف الجدول من بيئة البيانات نتبع الخطوات التالية: - 
في (ata Environment Designer‏ نختار الجدول المطلوب. 
من lÃئnة Remove رlتخi Data Environment‏ 
ويمكن أيضا عن طريق نقر الزر الأيمن للفأرة على الجدول المطلوب واختيار ٥0۷”ء۸‏ من القائمة 
المختصرة التي ستظهر . 


ه .تحديد العلاقات في Data Environment Designer‏ 
عند إضافة جداول إلى ٤۷۲٥٣۳۴۸۲‏ واه( لها علاقات ثابتة في قاعدة البيانات» فإن هذه العلاقات ستضاف 


بصورة أوتوماتيكية إلى ٤عص,صه‏ ]اہم مtه2.‏ إما إذا كان الجدول لا يمتلك متل هذه العلاقات التابتة فيمكن 
إنشاء العلاقة في (aa E ۸۷1۲0۸۳0٤1۸۲٤‏ عن طریق: - 

نؤشر الحقل من الجدول الرئيسي مع ضغط زر الفأرة ونعمل له عں5 (استمرار ضغط زر الفأرة) ونسقطه عل 
الفهرسة المطلوبة في الجدول التابع كما في الشكل .)١- ٤(‏ 


2 Form Designer - FormDocl 


CUS a OME 


arder_dsc 


ER id order mek 
company require_by 
contact shipped_oan 
title freight 
address . UElndexes: 
city cuskt_id 
regiorı ermp_id 
postalzode arder_id 
country = 


ا 


Drag fields to indexes to join tables. 


الشكل ٤(‏ -) مثال لإنشاء علاقة بين جدولين في Data Environ ent‏ 


AT-TT] 


و . تحدیث ںتٽ ata Environment Designer aA‏ 
لغرض تحديث العلاقة نتبع ما يلي: - 
في سەلWin Properties‏ نختار العلاقة («0ناها»ءR)‏ من خلال مربع اءءزطا0. الخصائص المرتبطة 
بالعلاقة تقابل الإيعاز ات .Set Skip gy Set Relation‏ 
خاصية (Default) aڍi gضgت RelationaIExpr‏ سم الحقل المفتاحي )Primpary Key)‏ للجدول الأب. 
وإذا کان الجدول التابع مفھرس علی شکل تعبیر (10۸ء٤٥إم×E)‏ فإننا نحتاج إل تخر rصRelationalExp‏ 
إلى هذا التعبير . 
إذا كانت العلاقة ليست من نو ع y«ة10-۷-ع01‏ نغير خاصية ر «ة۷× 0,۴۲١‏ إلى قيمة ۴.> وهذا يقابل 
.Set Skip jgدڊ Set Relation jl‏ 
تغيير خاصية yمة۷1٧ 0٥۸۴۲0‏ إلى قيمة .1. يقابل استخدام إيعاز منج؟ 561 والذي يعني أنه عند الانتقال 
عبر قيود الجدول الأب ۴۵۲٠”۲(‏ م1ط1۵) فإن مؤشر القيود سوف يبقى مؤشرا على نفس القيد في الجدول 
الأب إلى أن يتم انتقال المؤشر على جميع القيود المرتبطة في الجدول الابن (عاطة٣‏ 14ط٣).‏ 


ملاحظة: - إذا كان لدينا علاقة رمة۷-١٠-0«6‏ فيجب أن تكون قيمة خاصية yر«ة۷٧‏ 016۲0 هي .1. حتى 
لو كان لدينا علاقة ثابتة وموجودة (1pطكر Rel] at!‏ ntعPesist)‏ في قاعدة البيانات. 


Single and Multiple Document Interface slil . j 


يوفر ۷۴۶ إمكانية إنشاء نوعين من التطبيقات وهما: - 

Document Interface (MDT)‏ eاMutip:‏ - تطبيق يحتوي على شاشة رئيسية واحدة وبقية الشاشات 
محتواة فيها أو عائمة على سطحها. وكمثال على 21( هو الشاشة الرئيسية لتطبيق ۷۶۴۴۲ فهي تحتقوي 
Designer Windows gle ş «Edit Window «Command Window yle‏ . 


Document Interface (SDI)‏ eاوSin:‏ - تطبيق يحتوي على شاشة واحدة (أو عدد من الشاشات) 
المستقلة عن بعضها البعض في الظهور على شاشة سطج لتب .(Windows Desktop)‏ 


ولغرض إنشاء هذه الأنواع من الشاشات فإن ۷۴۴ يوفر عدة أنواع من النماذج: - 

Form‏ dاChi؛‏ - هو ۴0۲۳ محتوى ضمن شاشة أخرى» تستخدم في إنشاء 121. وهذا النموذج لا يمكن 
تحریکه خار ج حدود النموذج الأب (۳إإ٥۴‏ ا١ءإه۴)ء‏ وإذا تم تصغير نافذة الأب (عzنصنصنص)‏ فإن هذا 
۴0M‏ يحصل له عizصنصنصط‏ أیضا. 
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صديق قيس عبد الر حم الدوسري 


EEE 


:Eloating Form‏ - هو ۴o۳‏ تابع إلى ۴٥۲۳‏ e«۲ع۴ar‏ ولکنه غیر محتوی ضمنه»ء ویمکن تحریکه إلى أي 


" ء۶ 


موضع في الشاشةء وإذا تم تصغير نافذة الأب فإنه يصغر معه. يستخدم هذا النوع لإنشاء 191×. 


"0p Level Form‏ - ھور ۴0m‏ مستقل بدون ۴0۲٥۳۵‏ ۴4۲۴۸1 یستخدم لإنشاء تطبيقات 821 أو لأن يكون 
Parent Form‏ يحتوي على Forms‏ أخر ی. 


, VFP ف„‎ Forms أنواع‎ )٤- ٤( ويوضح الشكل‎ 


Top Level Form 8× Floating Form 


Microsoft Yisual FoxPro EE TIDUEE 5 
File Edt Yiew Tools Program Wind | | 


mm) olla al EE 
e a E OK | Cancel | 
Name ll 


Top-lewel forms are Floating forms can 


independent wvirdoumys that ۴ appear on top of 
cah contain child virda, Ei EI Eî their parents. 
and appear in front of or 


behind other windows. — 
Name | 
Phone | 


L hild rms are contained within ã 
parent virto. 


الشکل )٤١ ٤(‏ أمثلة علی ص٣٥۴‏ 
. تحديد نو ع النموذ < 
يتم إنشاء جميع ۴١۲۳١‏ بنفس الطريقةء ولكن يمكن تحديد نوعه من خلال خصائص معينة في نافذة 
الخڏھصlئص (Properties Window)‏ . 


لتحدید ۴٥۲۳‏ 14ط نت 
* نغير قيمة خاصية 0لم 0WW٥ط؟‏ إلى أحد القيم التالية: - 

, ۷۴۴ -النموذج الأب هو النافذة الرئيسية للتطبیق‎ : 1n Screen 

Form‏ Leve1-0pآ‏ .1 : - النموذج الأب هو النموذج الفعال عندما يتم استعراض النموذج الاإبن. يتم 
استخدام هذا الاختيار إذا اردنا أن يظهر النموذج الابن ضمن أي ۴٥۲٥‏ 1e۷e1-م٥٣.‏ 
* نغير خاصية 21۴٥۲٥‏ إلى .1. إذا أردنا أن يكون الابن مرتبط بالأب عند عمل ٥zنصن×هص‏ أو نغيره 
إلى .۴. إذا ردنا أن يستقل النموذج الابن إلى نافذة منفصلة عند عمل عizص1×ة"‏ له. 


i Floating Form دıدھتأ‎ 
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صديق قيس عبد الر من الدوسري 

* نغير قيمة خاصية س0ل "٥W W‏ إلى أحد القيم التالية: - ٠‏ 
Screen‏ ہ1 : -النموذج الأب هو النافذة الرئيسية للتطبیق ۷۴۲ . 

Form‏ eve1ا-0p"‏ ہ1 : - النموذج الأب هو النموذج الفعال عندما يتم استعراض النموذج الابن. يتم استخدام 
هذا الاختيار إذا أردنا أن يظهر النموذج الابن ضمن أي ۴٥۲٥‏ 1e۷e1-م٥٣.‏ 

* نغير خاصیية k0pءم(‏ إلى .1.. 


لتحدید ٦ ٥pم-]مہمع[ ۴٥۲٣۳‏ نتبع ما پلي: - 


.As Top-Level Form - Y yl ShowWindow ةيصاlخ‎ ةnيق نغیر‎ * 


إخفاء الشاشة الرئيسية لتطبیق ۷٣۴۴‏ 
إذا کنا نعمل في ۴٥۲٥‏ 1ع۷ع-ط٥۲‏ فإننا قد نرغب في عدم إظھار الشاشة الرئيسیة للتطبیق ٠۷۴۴‏ ولغرض 
عمل هذا الشيء فإننا نتبع الخطوات التالية: - 
* في الحدث )E۷۵٣٤(‏ المسمی ا٤اہ[‏ داخل ۴٥۲۳‏ نكتب العبارة التالية: - 
Application. Visible = .F.‏ 

* فی الحدث المسمی ۷إہ)یم داخل ۴٥٣۲۳‏ نكتب العبارة التالية: - 

Application. Visible = .T. ٠ 
. Form التابعة إلى‎ Methods أو‎ Events في أحد‎ his۴0rm.Re[ 2€ ويجب التأكد من وجود العبارة‎ 


ط . التوسع بالنماد ڊwlتخدlم Form Sets‏ 


يمكن. التغامل مع عند من التماذج باستخدام ا56 ددإه؟ والذي يمتلك الخضائص للتالية::- 
من الممكن إظهار أو إخفاء كل كص۲إه۴ في نفس الوقت. 

#من الممكن التعامل بصورة مرئية (رااهuائ۷)‏ مع عدد من ۴٠۲۳١‏ للسيطرة على مواقعها. 

کون کل یط۴ في 6؟ ۴٥۲۳٣‏ تشترك في ملف شاشة واحد (.×٥ء)‏ لذا کل وصإه۴ تشترك في 544 
environment‏ واحدة. ولهذا السبب إذا حركنا إمامزمم اهعم في أحد و۴۲۳ فإن هذا التحريك سینعکس 
في بقية ۴٥۲۳٣5‏ التي ننتمي إلى نفس ع5 ,۴٥۲٣١‏ 


یمکن إنشاء )56 ۴٣۲۳‏ عن طریق ما یلي: - 

من قائمة اختیار 1mثF‏ iختlر .Create Formset‏ 

ولغرض إضافة ١٣ا٥۴‏ إلی Se‏ صإ٥۴‏ من قائمة اختیار ۴٥۲٥‏ نختار Add New ۴٥۲٥۳‏ . ولحذف 
۴۳ موجود داخل )58 ۲۳٣۴ء‏ من مربع ۴٥‏ الموجود أسفل Form Designer‏ نختار 0۲m‏ ۴› ثم من 


. Remove Form رlتخi‎ Form رlيتخا قائمة‎ 
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Form Controls _gذlniلl مسیطرات‎ . 


الشكل )١- ١(‏ يبين التصنيف الهرمي لصنوف کائنات ۷۴۴ . 


Yisual FoxPro Objects 


Lortrals Lontainers 


Lortalner 


Lambo Box Forrn 


Lommand Button Grid 


Lolurmn 


8 
- 
EE 
n 
@ 


Control 
PagEFtramEe 
Edit Box Page 


Header Tool bar 


Hyperlink Option Button Group 


۵ 91E 
4 CE 
| + | © 
ا‎ m| 

#8 


Image Lommand Button Group 


Label 

Lina 

List Box 

LE Bound antral 

LE Cortainer Control 

Project Hook LEGEND 

Shape ك‎ EE Mon-vi sual 


Spinner 


"E 
Î #E 
GI 
Bea 
0 
2 


الشكل )٠- ١(‏ التصنيف الهرمي لصنوف کائنات ۷۴۶ 


من الشکل )١- ٥(‏ یتبین لنا أن صنوف ۷۴۲P‏ تقسم إلى قسمين رأıسييj‏ و Container Classes lak‏ & 

۴0۲۳١ وبشكل اخر يمكن رؤية الصنوف من وجهة نظر أخرى حيث يمكن أن يحتوي‎ ہ0n-Cntainer‎ Classes 
. (4)4 على نوعین من ءا0٣٤" : - النوع الأول من كاهإ)«ه٤ يرتبط مع 24( والنوع الثاني غير مرتبط مع‎ 
سوف تخزن في مصدر بيانات المسيطر‎ ٣٥٣٤۲٥1 فعند تعامل المستخدم مع كآ[ه٣صه٣ مرتبطة مع 4)4( فقيمة هذا‎ 
Control يتم ربط‎ .( Variable) أو متغير‎ (ھط1e‎ ۴ e14( والذي یمکن أن یکون حقل في جدول‎ )(هta‎ Sour ce( 
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مع 0)4 عن طريق التعامل مع خlاصıة «(Contro1Source)‏ 


صديق قيس عبد الرحمن الدوسري 


التي تربط المسيطر مع البيانات هي (عc .)Rec٥۲480 ur‏ 


e 


نتمیز 


656م في ۷۴۴ بمرونتها عند الاستخدام. لذلك هناك عدد من المسيطرات التي يمكن استخدامها لإنجاز 


عمل محدد» ولهذا السبب فإنه يجب إيجاد اسلوب ثابت لاستخدام المسيطرات حتى يتمكن مستخدم النظام من معرفة 
وتوقع ما يمكن أن ينجزه عند رؤيته لواجهة الاستخدام والشاشات المصممة من قبل مصمم النظام. adڌڈږں LABEL‏ 


یوجد فيه الحدث ٤۷٥٣۲‏ نا٣‏ ولكن المألوف لدی المستخدمین أنه یتوقع أن ٤٣ء۷٤‏ )عزاZ)‏ هو عن طريق 
.COMMAND BUTTONS‏ 
معظم العمليات التي يرغب مصمم النظام من درجها في النماذج تقع ضمن واحدة من الأقسام التالية: - 


إعطاء المستخدم مجموعة من الخيارات المحددة مسبقا. 
قبول إدخال المستخدم للبيانات التي لا يمكن تحديدها مسبقا. 
قبول إدخال المستخدم للبيانات ضمن مديات محددة. 
السماح للمستخدم من إجراء فعاليات محددة. 

إجراء فعاليات محددة في أوقات معينة. 


وکن ا 


Option Button Groups pli . ا‎ 


هو عبارة عن ٥01٤116١‏ يحتوي على عدد من الخيارات» يتيح للمستخدم تأشير أحد الخيارات بدلا من إدخال 

البيانات إلى القاعدة لضمان عدم حصول خطاً في الإدخال. 

عند إنشاء اا6 ١٠٥1ام0‏ فإن القيمة البديهية لعدد الخيارات فيه هو (١)ء‏ ويمكن تغيير عدد الخيارات عن 

طريق تغيير قيمة الخاصي Button CoUnt‏ . 

الخاصية ما۷ يؤشر رقم الاختيار الذي تم تحديده من قبل المستخدم» فمثلا إذا اختار المستخدم الخيار الرإيع 

فان a1ue‏ لهذا ماع «ەiامە‏ سوف يساوي .)٤(‏ 

إذا كانت الخاصية ءعcإ0u؟015إ)eon‏ هو عبارة عن ١ع]ء‏ ٣2ط‏ فإن قيمة الخاصية عuاج۷‏ سوف تكون 

عنوان الاختيار (١10امة٤)‏ ولیس رقمه. 

يمكن التعامل مع کل خيار داخل ۲0ع ١٥1امه‏ على حدةء ويمكن تغيير خصائص كل خيار أو كتابة 

الإيعازات داخل الصيغ (sئل0ط)ء)‏ التابعة لكل خيار على حدة. 

يمكن تغيير خصائص الخيارات أثتاء وقت التصميم (عءص11 «عاءم0)»ء فمتلا إذا أدرنا أن نغير عنوان 

- مە فنکتب الإیعاز التالی:‎ oice اسمه‎ option group فی‎ op) ٣)us الخیار المسمی‎ )aption( 
ThisForm.opgChoice.optCust.Caption = "Sort by Customer" 
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صديق قيس عبد الر حم الدوسري 
E‏ 


كماو گن نر خصباتضن الخيارات اء قت التنفيذ (Run Time)‏ عن ر اسشظام الخاصية Buttons‏ 
عن طريق تحديد رقم الخيار» فمتلا إذا كان ائu٣)مه‏ هو ثالث خيار في ماتاع «٥0نامه‏ المسمى 
Choice‏ مە فنکتب الإیعاز التالی: - 

ThisForm.opgChoice.Buttons(3).Caption = "Sort by Customer" 
فمثلا‎ S٥411 ولتغيير خاصية محددة لكل الخيارات في ماهإع «١٥نامه نستخدم الصيغة (0dط)ء.) المسمى‎ 
- إذا أردنا أننعمل عاطهء1 لكل الخيارات في مااع «0نامه اسمه upهMy6عمه فنكتب الإيعاز التالي:‎ 


ThisForm.opgMyGroup.SetAll("Enabled",.F.,"OptionButtons") 
عندما تكون الخيارات (كئ١٥))8) في حالة ماطهء1( فإنها تظهر بلون خلفية يمكن تغييره من خلال الخاصية‎ 
کما ویمکن عمل‎ .Disھط[م‎ 4۴٥۲٣٥10۲ وبلون آمامي یمکن تغییر من خلال الخاصیة‎ DisabاedBackCo1or‎ 
الخاصية dءاطهہع التابعة إلى upهإع «٥نامه للقيمة ۴۰. وينتج عنه أن كل الخيارات تكون غير فعالة‎ 
.(disabled) 
من‎ Contr01 S0r ce يمكن استخدام الخاصية عں اه۷ لتحديد أي خيار تم تأشيره» فإذا كانت الخاصية‎ 
نوع بیانات icاeصںN) وکان لدینا up٥إع «٥نامه مكون من خمسة خيارات وتم ضغط الخيار الثالث مثلا فإن‎ 
م1 ستكون مساوي إلى (۳) وإذا لم يتم ضغط أي خيار فإن اه۷ ستكون مساوية إلى (صفر).‎ 


Drop Down List Box ھ‎ List Box pمlدختwl‎ . ب‎ 
- ۲ فيه خاصیة عارا؟ مساویة إلى‎ Combo Box )هر‎ Drop-Down List Box و‎ List Box المسيطرات‎ 


stاopdownاD).‏ تتيح للمستخدم قائمة متحركة انا مااةااهإءء تحتوي على عدد من الخيارات أو أجزاء 
من المعلومات. الاختلاف بينهما أنه في ×0ط ا11 يوجد عدد محدد من العناصر (١1ع)1)‏ ممكن ان تكون مرئية 
دائما في کل وقت» بينما في ×0ط istا drop down‏ هناك فقط عنصر واحد یکون مرئیاء إلا ان المستخدم 
يستطيع أن يعمل زاء لكي يستعرض قائمة متحركة لعرض عناصر .drop down list 10x‏ 

ويوڪح الجدول أدناه بعض خصائص (٥×‏ ءا و ×٥ط‏ ایا م سمل مهال والتي غالبا ما یتم تغيرها أشاء 


.Design Time 


Property 
ColumnCount 
ControlSource 


MoverBars 


Multiselect 
RowSource 


Whether the RowSource is a value, a table, a SQL statement, a query, an array, a 
ROMSOuTEETYDE list of files, or a list of fields. 


list box / drop down list 0x جدول يو ضح بعض خصائص‎ 
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2 جامعة الانبار - كلية ا لحاسو ب صدیق قيس عبد الر حر الدو سري 
N E 0000000000000000 E I RR E‏ 
للاحظة: - الخاصية عuاه۷‏ التابعة إلى List‏ يمکن أن تکون CL n DIS‏ . والقيمة البديهية هي ءأإعصناه. وإذا 
كانت الخاصية R0 WS 0u]‏ من نو ع إماءهإهطء فنضع قيمة فار غة (رامإه) في الخاصية م1uه۷‏ إذا كنا 
نريد أن تعكس الخاصية عںاه۷ بيانات الخيار المنتخب. ويمكن إدخال قيمة فارغة عن طريق ضغط 


. Properties window لهذە الخاصية في‎ B ACKSPACE laz, SPACEBAR 


يوضح الجدول أدناه بعض الصيغ (ءل0طام.) بالنسبة إلى ×0ط ائا. 


Method Description 


AddItem Adds an item to a list with a RowSourceType of 0. 
Removes an item from a list with a RowSourceType of 0. 
Requery Updates the list if the values in the RowSource have changed. 


يمكن إملاء ×0ط 1ء11 بعناصر من مصادر بيانات مختلفة عن طريق تغيير llخlصٻة RowSourceType‏ 
وllخاصية RowSource‏ . 

الخاصية ٥م‏ راء ءاه 5سهR‏ تحدد نوع مصدر البيانات الذي يغذي list box‏ (مثلا eاطta‏ أو array‏ ...lلخ(.‏ 
وعند تحديد نوع المصدر يمكن بعدها تحديد المصدر نفسه عن طريق الخاصية R0 wS0u ce‏ . 


ويوضح الجدول ادناه أنواع مصادر البيانات بالنسبة إلى List Box‏ . 


RowSourceType Source of the List Items 


None. Programmatically add items to the list. 


Value 


Popup. Included for backward compatibility. 


دناه توضيح لأنواع مصادر البيانات بالنسبة إلى ×0ط اا, 

None‏ = إذا كان ype‏ 1ءRowSource‏ يساوي صفر» نستطيع إضافة عناصر إلى ءآ[ عن طريق الصيغة 
16ل وكما في المتال التالي الذي يضيف العناصر إلى ء11 اسمه ائال[1۷Mء1‏ داخل النموذج الذي اسمه 
:frmForm1‏ - 
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frmForm1.IstMyList.RowSourceType = 0 
frmForm1.IstMyList.AddItem(" First Item") 
frmForm1.IstMyList.AddItem(" Second Item") 
frmForm1.IstMyList.AddItem(" Third Item") 


والصيغة ١٠ء)آء۷رمصم R۸‏ يتيح لنا حذف العناصر من 1ء11 وكما في الإيعاز التالي: - 

frmForm1.IstMyList.Removeltem(2) 
مساوية إلى (١)ء فإننانستطيع وضع قيم متعددة للخاصية‎ RowSource1 ype إذا عملنا‎ - Value 
- وكما في المثال التالي:‎ RowSource 


Form1.IstMyList.RowSourceType = 1 
Form1.I1stMyList.RowSource = "one,two,three,four" 


Ais‏ - إذا عملنا Row Source ype‏ مساوية إلى (١)ء‏ فإننا نستطيع إدراج حقل واحد أو أكثر من جدول 
مفتو ح. فإذا كانت الخاصية ٣٣01٣٤‏ ناه مساوية إلى ٠(‏ أو )١‏ فإن أول حقل في الجدول سيظهر في اكا 
×0طء وإذا تم تغييره مثلا إلى (۳) فإن أول ثلاثة حقول ستظهر في ×٥ط‏ ء11 وهكذا. 


SOL Statement‏ - إذا عملا RowSourceType‏ مساویة إلى (۳)ء نستطیع وضع ا@8؟- 1٣٤ا SE‏ في 
خاصية ع٥۲‏ ا50 ۸0W‏ والمثال التالي یوضح هذا: - 


SELECT * FROM Customer INTO CURSOR mylist 


إذا تم تغيير ۸0۷501۲٥٥‏ عن طريق البرمجة» يجب تذكر أن iضg .quotation mark Jil SELECT‏ 


:Query‏ - إذا عملنا Row Source ype‏ مساوية إلى (٤)ء‏ فنستطيع أن نجعل مصدر بيانات ×0ط انا 
هو عبارة عن نتيجة استفسار (رإاQue)‏ مصمم باستخدام ۴۲؟”عذوەD‏ رإمQu.‏ والمتال التالي يوضح 
ذلك - 

THISFORM.List1.RowSource = "region.qpr" 


Array‏ - إذا عملنا Row SourceT ype‏ مساوية إلى (١)ء‏ يمكن تغذية ×0ط اءزا من مصفوفة (رهإ٤ه)‏ تم 
إنشاؤها من أي مكان آخر في التطبيق. 


° 


صديق قير عبد الر همر ال 


ملاحظة :3 ا ere‏ الإمكان استخدام arfuy‏ ا بیانات» ها س الكثير من ن المشاكل). ٠‏ 


:Fields‏ - إذا عملنا Row Source ype‏ مساوية إلى (١)ء‏ نستطيع تغذية ءا ×ط عن طرق حقل من جدول 
أو عدة حقول مفصولة بفوارز . 
عند استخدام ١1ع‏ نستطيع وضع المعلومات التالية في خاصية ع٣‏ 1لR0WS0:‏ - 

field 


alias.field 
alias.field,field,.. 


على العكس من )١(‏ يمكن درج حقول الجدول هنا بغض النظر عن ترتيبها الأصلي في الجدول. 

Files‏ = إذا عملنا Row Source Type‏ مساوية إلى (۷)ء فسيتم تغذية ×0ط ء11 من الملفات الموجودة في 
المكتبة الحالية (رإهاءعإزل ار۲إنء)ء إضافة إلى وجود خيارات أخرى لتغيير القرص ولتغيير المكتبة. كما في 
الشكل أدناه. 


.DBF Files EHIEI Eî 


۷ فيه تساوي‎ R0 wS 0u re1 ype ×0ط ءا قيمة الخاصية‎ )١- ١(لكشلا‎ 


إذا أردنا أن نستعرض ملفات ذات استطالة محددة» نغير خاصية ce‏ uه؟سR0‏ إلى الاستطالة المطلوبة (متلا 
DBF‏ (. 


Structure‏ = إذا عملنا RowSourceT ype‏ مساوية إلى (۸)ء فسيتم تغذية ×0ط ءا من حقول في جدول 
یتم تحدیده عند تغییر ٥0۷501۲٥٥‏ 8۸. هذا النوع يكون مفيدا إذا اردنا أن يقوم المستخدم بالبحث عن حقل معين 
لترتيب الجدول عليه. 


pupد:‏ - هذا النو ع وضع لأجل التوافق مع الإصدارات القديمة للتطبیق ۷۴۲ . 
إنشاء ×80 ء1 ذات أكثر من عمود 


SEKAN 
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القيمة البديهية لعدد الأعمدة في ×٥ط‏ ءا هو (١)ء‏ إلا أنه يمكن إنشاء ×0ط ءا ذات أكثر من عمود وذلك عن 
طريق تغيير خاصية ٤٣ا٥‏ ٣مصداه‏ إلى عدد الأعمدة المطلوب» وتغيير خاصية ءطال¡W Colum‏ إلى 
ااك طت کا کل حل که کن ف ان2 : 


THISFORM.listbox.Column Widths = "10, 15, 30"‏ 
وبعدها نغير خاصية ع٥مpرآءcإs0uسه PR‏ إلى (“ - sءهامز۴).‏ وأخيرا نغير الخاصية ce‏ uهwSهR‏ إلى 


الحقول المطلوب عرضها. كما في المثال: - 


form.listbox.RowSource = "contact,city,country" 


چ . ulتخدlۃ Check Box‏ 
يمكن استخدام ×0ط kءعطC‏ للسماح للمستخدم بالتعامل مع >llة .(True & False) Boolean‏ 


هناك فقط أربعة حالات لقيمة خاصية عداه۷ بالنسبة إلى ×0ط ءعط)٤»‏ ويوضح الجدول أدناه هذه الحالات 


الأربعة. 


ا 


ملاحظة: - يمكن للمستخدم إعطاء قيمة N01‏ إلى ×0ط Check‏ عن طریق ضغط .٣C)1+0‏ 


إذا أعطينا الخاصية عءإ180u١١ا«ه)‏ بالنسبة إلى ×0ط عط بأن تشير إلى حقل منطقي في جدول بيانات 
£ie1d(‏ l0gica1)ء‏ فإن ×0ط )ءعطء سوف يظهر على شكل مربع داخله علامة صح إذا كانت قيمة الحقل .1. 
.NULL‏ 


د . استخدام ×60 )×eآ'‏ 
المسيطر ×٥ط‏ ا×ع] هو المسيطر الأساسي الذي يسمح للمستخدم من إضافة وتحديث قيم البيانات لكل أنواع 
البيانات ما عدا مMem.‏ 


۸7-7] 


ODODE O O 
۰ 


ا ی ا ا 


DDD ODOR 1 2 PPDP LI 0 0‏ 
وأتاشي او تغيد العبارة الل ا في text box‏ نقوم او لا بتاشیر خاصية alue‏ & بتغبد 


خاصية ع٥‏ 1501١۲0اnه)‏ بالنسبة إلى ×0ط )×ع) فإن القيمة المعروضة فيه سوف تخزن في الخاصية عuإج۷‏ 
وكذلك في الحقل أو المتغير المقترن بالخاصية ure‏ S0؟01إntهC.‏ 


ولغرض التحقق من القيمة المدخلة في ×0ط ا×ع) نكتب عبارات السيطرة في الصيغة (4١0ط۲ع.)‏ المقترنة 
بالحدث 4اه . فإذا كانت القيمة الداخلة خاطئة فإن قيمة الرجو ع سیکون (.۴.) أو .٠‏ وإذا رجعت قيمة (.۴.) 
ستظهر عبار ة "اامم] 4ناه۷ہ!". وإذا أردنا أن نظهر العبارة الخاصة بنا نستخدم WA1۲ W1ND(0¥‏ أو 
)(MESSAGEBOX‏ في عبارات ۷114 ونرجع .٠‏ فمثلا إذا كان لدينا ×0ط ×6] ندخل فيه قيمة تاريخ في 
المستقبل» فإننا نستطيع التحقق من ذلك عن طريق كتابة العبارات التالية في الحدث 14اه الخاص بالمسيطر 
×0 ×ع)» وکما بلي: - 


IF CTOD(THIS.Value) < DATE( ) 
= MESSAGEBOX("' You need to enter a future date",1) 
RETURN 0 

ENDIF 


وإذا أردنا أن نختار كل العبارة في ×0ط ×ع)] عندما يحصل عليه تأشير نغير قيمة الخاصية .SelectOnEntry‏ 
كما ونستطيع استخدام خاصية )ئة۷1)م,1 لتحديد القيمة التي يمكن إدخالها في ×0ط )×ع] ونستخدم خاصية 
۴ لتحديد كيفية ظهور العبارة في ×0ط ×ع). 

وإذا أردنا أن لا تظهر العبارة التي ندخلها إلى ×0ط ا×ع) (مثل واجهات كلمات المرور 0۲۵ 5Wءھ۴P)‏ نغير قيمة 
خاصية ٣12۲‏ 1إ0سءوه۴ بالنسبة إلى ×0ط ا×ع] إلى * أو أي رمز حرفي عام آخر. 

كما ويمتلك ×0ط ×6] عدة خصائص يمكن تغيير ها لتسهيل عملية إدخال قيم التاريخ والجدول أدناه يوضح هذه 
الخصائص . 


ETE  Desrpin 
Century Whether the first two digits of the year are displayed or not 


Format the date in the text box to one of fifteen predetermined 
DateFormat 

formats, such as American, German, Japanese. 
EEE Setting StrictDateEntry to 0 - Loose allows a user to enter dates in 
DIrICLIACENIrY : 

more flexible formats than the default 99/99/99. 
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RR ER E 


DDE E RRR E 
والتي غالبا ما ینم التعامل معها.‎ text box ویبین الجدول أدناه يعض الخصائص بالنسبة إلى‎ 


Description 
Whether the contents of the text box are left justified, right justified, 

Sa centered, or automatic. Automatic alignment depends on the data 

NRE type. Numbers, for example, are right justified and characters are left 
justified. 

The table field or variable whose value is displayed in the text box. 
Specifies the data entry rule each character entered must follow. For 

a specific information about InputMask, see Help. 


Whether the contents of the text box are automatically selected when 


E IGOR the text box receives the focus. 
Tabs Whether the user can tab to the control. If TabStop is set to .F., a user 
Labstop can still select the text box by clicking it. 


هھ . استخدام Edit Box‏ 
عند استخدام ×0ط الع فإننا نسمح للمستخدم من التعامل مع حقول 0”إ٥‏ أو الحقول من نو ع characte‏ 
الطويلة جدا. ×0ط الع له عدد من الميزات منها السماح بإدخال البيانات بحرية والتنقل عبرها باستخدام الأسهم 

.scrollbars pals page down ۾‎ page up yi 
نستطيع السماح للمستخدم من تحديث ملف من نوع )×0 والنموذج أدناه يمثل هذا الشيء.‎ 


Text file: 


ق 


pen File Save 
لتحديث ملف من نوع {×م)‎ E1٤ 8× مثال حول استخدام‎ )٤- ١( الشكل‎ 


الاختيار OK‏ يستخدم لإغلاق النموذج ونکتب فيه العبارة 


Release ThisForm yÎThisForm.Release 


۸-۳٤ 


الاختيار cmdOpenFile ya open File‏ و lلاختıار .(cmdSave ga Save‏ 
الجدول التالية يبين العبارات البرمجية التي تكتب في الحدث عcنا٣‏ الخاص بالاختیار ع۴ ۸عpه.‏ 
Code‏ 


REA Create a cursor with a character field to hold the name of the text file and a 
¢ ( کک‎ es ) memo field to hold the contents of the text file. 


AFFEND B Add a blank record to the cursor. 


REPLACE textfile. FileName WITH ; Use the GETFILE( ) function to return the name of the file to open. Store the 
GETFILE ("TXT") name in the FileName field of the cursor. 
IF EMPTY (textfile. FileName) If the user chooses Cancel in the Get File dialog box, the FileName field will 
RETURN د‎ 
NDI be empty and there will be no file to open. 


THISFORM.edtText.ControlSource = ; 
"text file.mem" Set the ControlSource of the edit box on the form. 


APPEND MEMO mem FROM ; : ر‎ 
(text file. FileName) OVERWRITE Fill the memo field with the text in the file. 
THISFORM. Refresh 


THISFORM. cmdSave. Enabled = .T. Enable the Save button. 


والجدول التالي يحتوي على العبارات التي تكتب في الحدث نا٣‏ الخاص بالاختيار م84۷ . 


Code 


COPY MEMO textfile.mem TO ; 
(textfile. filename) 


Property 


Whether the user can insert tabs in the edit box instead of moving to the 
AllowTabs next control. If you allow tabs, be sure to indicate that users can move to 
the next control by pressing CTRL+TAB. 


HideSelection 


ReadOnly 
ScrollBars 


. wlتخدlۃ Combo Box‏ 
×0ط combo‏ يمتلك خو اص (٥×‏ ء11 وخواص ا×ع] ×٥ط‏ معا. هناك نوعان من ×٥ط‏ 0طاصہہءc‏ وھما -pہDr‏ 


.؟tراع عن طریق تغییر الخاصیة‎ c٥٥ و istا down-0pاD. ویمکن تحدید نو ع ×0ط‎ down combo 
(method) يمكن إضافة عنصر جديد في 0طا٣إهء «wس٠ل-مطه٠إل عن طريق كتابة العبارة التالية في الصيغة‎ 
- المقترنة بالحدث ل۷11 وكما يلي:‎ 
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×00 وکما بلي: - 


lItemExists = .F. && assume the value isn’t in the list. 
FOR 1= 1 to THIS.ListCount 
IF THIS.Listû) = THIS.Text 
lItemExists = .T. 
EXIT 
ENDIF 
ENDFOR 
IF !ItemExists 
THIS.AddItem(THIS.Text) 
ENDIF 


الجدول التالي يبين بعض خصائص ×0 0١٠٥ء‏ والتي يتم التعامل معها غالبا. 


Property Description 


Specifies the table field where the value that the user chooses or 
enters 1s stored. 


DisplayCount Specifies the maximum number of items displayed in the list. 


Mask For drop-down combo boxes, specifies the type of values that can be 
MPU typed in. 


I 

Specifies whether the control tries to match an item in the list as the 
IncrementalSearch 

user types each letter. 


Specifies the source of the items in the combo box. 


Specifies the type of the source for the combo box. The 
RowSourceType values for a combo box are the same as for a List. 
For an explanation of each, see Help or the discussion on list boxes 
earlier in this chapter. 


ControlSource 


RowSourceType 


Specifies whether the combo box is a drop-down combo or a drop- 
down list. 


يستخدم ۲٥٣1مء‏ للسماح للمستخدم اختيار قيمة معينة من بين مجموعة من القيم أو طبع القيمة مباشرة داخل 
„Spinner‏ 

يتم تغيير قيمة الخاصية Keyboard 831g 21u‏ والخاصية Spinner8 igh 21u‏ وتوضع فيهما أعلى قيمة 
يمکن للمستخدم إدخاله في ٣۸۴۲‏ 1م؟. 

وبنفس الحالة بالنسبة للخاصية ع Keyboar4 0w V a] u‏ والخاصية 0w Value‏ rإعinnمS‏ حيث توضع فيهما 
أقل قيمة يمكن للمستخدم إدخاله في 6۲٣١1م؟.‏ 
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والجدول التالي يبين بعض خصائص ٥١‏ ١11م‏ والتي غالبا ما يتم التعامل معها. 
Property‏ 
user clicks the Up or Down buttons.‏ ا 
KeyboardHigh Value‏ 


The highest value that th 1l 1 hen th 
SoinnerHishValue 1e highest va ue that the spinner will display when the user 
SLICE Y LUG clicks the Up button. 
SEES E The lowest value that the spinner will display when the user 
SPINEILLOW Y UE clicks the Down button. 


ج . اwتخدpl Command Buttons Group g Command Buttons‏ 
من أكثر المسيطرات استخداما في التطبيقات» وغالبا ما توضع العبارات البرمجية في الحدث نا٣‏ داخل 


. Command buttons 


ويبين الجدول التالي بعض خواص 8)٥١‏ dمدصصه‏ الأكثر شيوعا. 
Property‏ 
Specifies that the code associated with the Click event of the command‏ 
Cancel‏ 
button executes when a user presses ESC‏ 
Caption Text displayed on the button.‏ 


DisabledPicture The .bmp file displayed when the button is disabled. 


DownPicture The .bmp file displayed when the button is pressed 
Enabled Whether the button can be chosen. 


Picture The .bmp file displayed on the button. 
ويمكن أيضا إدراج هااا dمصحمصصهء في ٥۲ع بحيث يمكن معالجتهم كلهم مع بعض أو كل واحد على‎ 
Command buttons حدة. وإذا أردنا أن نعمل مع صيغة (ل0طاعص) واحدة في الحدث ناح التابع إلى‎ 


مupداع»‏ فإن الخاصية عں اه۷ التابعة إلى ۲٥ع‏ سوف يکون فيه رقم 01)† ا8 إم2صصهع الذي حدث عليه 
)عنا. والمثال التالي يوضح هذا: - 
DO CASE‏ 
CASE THIS.Value = 1‏ 
WAIT WINDOW "You clicked " + THIS.cmdCommand1.Caption; NOWAIT‏ 
do some action‏ * 
CASE THIS.Value = 2‏ 
WAIT WINDOW "You clicked " + THIS.cmdCommand2.Caption; NOWAIT‏ 
do some other action‏ * 
CASE THIS.Value = 3‏ 
WAIT WINDOW "You clicked " + THIS.cmdCommand3.Caption; NOWAIT‏ 
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* do a third action 

ENDCASE 

ملاحظة: = إذا كتبنا عبارات برمجية داخل الحدث نا٣‏ التابع لھ command buttons jaض Buttons‏ 

SrOUp‏ فان هذه العبارات ستنفك حتی ولو کان هناك عبارات برمجية داخل الحدث Click‏ التابع إلى 


.command buttons group 


Timer Control plدختwl‎ . طb‎ 

يستخدم 11۳٥۲ ٥0٣٤۲01‏ لتنفيذ فعاليات معينة في أو قات محددة دون تدخل المستخدم. 
كل إ٥‏ ط1٣‏ توجد فيه خاصية اة۷إعام] والذي يحدد عدد كل«صهءمءناانص التي بين حدث وحدث آخر. خاصية 
1 فيها بعض التحديدات عند برمجتها وهي: - 

٥۹٦,٩ والذي يعني أن أکبر ۲۷۵1٤ا"] مسموح به هو‎ ۲٠٤۷٤۸۳٦٤١ هو بین ۰ إلى‎ nterv1 
يوم).‎ ۲٤١ ساعة (أكثر من‎ 

ليس مضمونا دائما أن يكون 1ه۷إه"1 متساوياء ولضمان الدقة يجب التحقق من kعهآاء‏ ١طعاءرء‏ داخل 
لحان 

إذا كان التطبيق يحتوي على تطبيقات أخرى تعمل حملا كبيرا على الحاسبة مثل م٥٥1‏ ع١هاء‏ معالجة 
Disk‏ معالجة 0۲۲ ۴»› معالجة kإمسtمعN‏ قد تؤدي إلى إيقاف ص1٣‏ . 


ويبين الجدول التالي اهم خواص ٣1.٣۴۲‏ . 


Property Setting 


If you want the timer to start working as soon as the form loads, set to 
true (.T.). Otherwise, leave this property set to false.) F.). You may 


Enabled . 
choose to have an outside event (such as a click of a command button) 


start operation of the timer. 


Interval Number of milliseconds between timer events. 


وكمثال تطبيقي على إ#ص.٣‏ نأخذ مثال الساعة الإلكترونية كما موضح في الشكل .)١- ١(‏ 


الشکل )٥- ٥(‏ مثال حول Timer‏ 
ويبين الجدول التالي المسيطرات داخل النموذج أعلاه (ملاحظة: - ص1٣‏ لا يظهر أُثاء ص1٣ .)Ru”‏ 


Control EET 
LoITime Gmin ÎÛ 
) o°..half a second ( 


Timer! menal 
Timer! Enabled 


د ]۸1-۳۸ 
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THISFORM.1bI1Time.Caption = Time() 
ENDIF 


مع تغيير قيمة خاصية اج۷إع)"! إلى ٠°٠١‏ كل”هءعءاانص (تقريبا ثانية واحدة). 


ي . استخدام esعھص]‏ 
يسمح ك٥ع1”4‏ من إضافة صورة إلى النموذج .)0.P.(‏ وتمتلك مع1."4 معظم الخواص والصيغ والأحداث 
مثل بقية المسيطرات» فيمكن تغيير الصورة أثناء التنفيذ وعمل )ع1ا أو أي حدث آخر . 
والجدول التالي يبين أهم خواص eعع1.4.‏ 


Property Description 
Picture The picture (.bmp file) to display. 


BorderStyle Whether there is a visible border for the image. 


If Stretch is set to O - Clip, portions of the picture that extend beyond 


the dimensions of the Image control are not displayed. If Stretch is set 
to 1 - Isometric, the Image control preserves the original dimensions of 


Sireleh the picture and displays as much of the picture as the dimensions of the 
Image control will allow. If Stretch is set to 2 - Stretch, the picture is 
adjusted to exactly match the height and width of the Image control. 

ك . استخدام e1‏ اھ 
یختلف 1٥ط[‏ عن ٥×‏ ا×ع] بما یلي: - 
J‏ يوجد .Data Source lq‏ 
لا یمکن تحدیث قیمتها بشکل مباشر . 
لا يمكن الانتقال إليها عن طريق طه1. 
یمکن تغییر خواص ١٥1م3٤‏ و ع1ط1ء۷1 برمجیا لیعکس ما هو مطلوب . 
ويبين الجدول التالي أهم خصائص 1ءطه]. 

Property Description 

Caption The text displayed by the label. 

AutoSize Whether the size of the label is adjusted to the length of the Caption. 

BackStyle Whether the label is Opaque or Transparent. 

Word Wrap Whether the text displayed on the label can wrap to additional lines. 
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. استخدام Shapes‏ 
يمكن إضافة الأشكال الهندسية إلى النماذج لتحسين النموذج أو لتقسيم كائنات النموذج إلى مجاميع» وييين 
الجدول التالي هم خواص كعم4ط؟ التي يمكن العامل معها في ع#ص1٣آ‏ دعوم( . 


Property 
Curvature 


FilStyle 


Whether the shape is plain or 3D. This only has an effect when the 


SpecialEffect Curvature property is set to 0. 


م . استخدام ٥م‏ 
يستخدم 111٥‏ بنفس استخدامات كءم512» ويبين الجدول التالي أهم خواص 11١"١‏ والتي يمكن التعامل معها 
اء Design Time‏ . 


Property Description 
Border Width How many pixels wide the line is. 


When the line is not horizontal or vertical, the direction of the slant. 
LineSlant Valid values for this property are a slash ( / ) and a backslash.(\ ) 


ن . استخدام Grid‏ 
هو عبارة عن 6۲« iها١ه)»‏ يحتوي على أعمدة كص ن1اه). وبالإضافة فإن ك" ناه بدورها تحتوي على 
header‏ وتحتوي على ك[هإا«هء» كل واحدة لها خصائصها وأحداثها وصيغها مما يوفر سيطرة كبيرة على 
عناصر 6114 . 
4 يوفر التعامل مع أعمدة وأسطر البيانات في النماذج» ولعل أفضل استخدام له هو في تصميم نماذج -ع٣0‏ 
٥-y‏ مثل نماذج وصولات الاستلام والصرف في المخازن. 
ولإضافة إإإ إلى النموذج» يتم اختيار 61d‏ من ٣01b2همt ]0rm contro1‏ ومن ثم نسقطه على شاشة 
النموذج ونعمل له عنإل إلى الحجم المطلوب. 
لتحديد عدد أعمدة لاع نغير الخاصية «١٤011٤‏ ”»ن1ه) إلى عدد الأعمدة المطلوب. وإذا عملنا قيمة هذه 
الخاصية مساوية إلى ٠١‏ فإن 2۲1١‏ سوف يحتوي على عدد أعمدة مساوية لعدد الأعمدة في الجدول المرتبط به. 
يمكن تحديث خواص أي عمود أو سطر في إ6 وذلك إما عن طريق نقر الزر الأيمن للفأرة لإظهار قائمة 
الاختيارات الخاصة بالمسيطر ونختار منه ال٤‏ أو عن طريق نافذة sس0لہذس‏ sع1اإمpمهإP‏ في مربع object‏ 
نختار العمود المطلوب تحديث خواصه. 
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ي 1 وإنه سوف يرسم إ 
نضغط الفأرة في أي موقع آخر من النموذج. 
ولتغير عرض العمود نحرك الفارة إلى الموقع بين عمودين في منطقة "٠406١‏ فيتحول مؤشر الفأرة إلى خط 
عمودي وتظهر فيه أسهم صغيرة بالاتجاهينء نختار العمود ونعمل له عنإل إلى أن نصل إلى العرض 
المطلوب. أو يمكن عمل ذلك عن طريق تغيير خاصية Width‏ ف„ .Properties Window‏ 
ولتغيير ارتفاع السطرء ندخل في حالة اله ونحرك الفأرة إلى الموقع بين أول وثاني سطر في لاع في الجهمة 
اليسرى من لع فيتحول المؤشر إلى خط أفقي وله أسهم صغيرة من أعلى وأسفل» نختار السطر ونعمل له 
8 إلى الارتفاع المطلوب. أو يمكن عمل ذلك عن طريق تغيير خاصية !عieاګ‏ umn'sاCo‏ في 
Properties Window‏ . 
ملاحظة: - يمكن منع المستخدم من تغيير ارتفاع الأسطر في فأ٣6‏ عن طريق تغيير قيمة الخاصية 
.„.F. yإ AllowRowSizing‏ 
ولتغيير مصدر بيانات ۲1ع (يمكن تغيير مصدر بيانات لاع ولكل ١٣٠اهء‏ على حدة أيضا) يتم اختيار 
ع ونختار الخاصية peر1ء›إuه45SإهءRe‏ والذي يمكن تغييره إلى ٠‏ - ٥1طه٠‏ إذا أردنا أن نفتح جدول 
ليرتبط به ۲4ع أو نجعل قيمته ١‏ - كها إذا أردنا أن نربطه بجدول مفتوح أصلا. وبعدها نختار الخاصية 
Recor dSource‏ ونكتب اسم الجدول أو sهذا4‏ ليكون هو مصدر بيانات ل1إع. وإذا أردنا أن نحدد الحقل الذي 
يرتبط بكل عمود نغير خاصية ع٥01۲ه)ه‏ للعمود المطلوب. 
ك امع الك من اه فر د ج ل ات اررض عن طرخ اا عن طرق جل 
الخاصية WAN ew‏ 10ا۸ مساویة إلى .1 .« وللسيطرة الأكثر على الإدخال نجعمل قتيnمهة AllowAddNew‏ 
مساوية إلى ۴ . ونستخدم بدلا .Insert jlzyl, Append Blank jl aie‏ 
واحدة من أكثر استخدامات 14ع هو في عرض قيود الجدول الابن بينما نستعرض قيود الجدول الأب عن 
طريق المسيطرات الأخرى» بحيث إذا تنقل المستخدم عبر قيود الجدول الأب فإن القيود التي ستظهر في لاع 
هي قيود الجدول الابن المقترنة بالجدول الأب. 
إذا كانت العلاقة بين الجدول الأب والجدول الابن موجودة في ١۷1۲١١۸۳١8٣٤‏ ههل الخاص بالنموذج فإن 
عرض عااقة رصجو"-٥ا-ع٥٣٠‏ بين الجدولين ستكون سهلة جدا. 
ولغرض عرض ٥۸۲٥ء‏ آخر (مثل ×0ط 0طاصهء»ء ×0ط )ععطc»‏ ...الخ) في أعمدة ٣ع‏ غیر text b٥×>‏ 
نتبع الخطوات التالية: - 

في س0لW¡n‏ sعiامpداP‏ نختار العمود المطلوب إضافة 1١١٠ء‏ إليه» فيظهر إطار حول 1۲14ع 

للدلالة على حالة 8di‏ . 
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صديق قر د ال 


î Properties - Forrnî 


Î Lolumrî 
EE Headerl 


Tentl ۴‏ 
الشكل (ه -( مثال على Lherckl‏ 0 


EÊ@ Lolımnd 
EA Headerl إضافه 1٥١إ٤«رهء إلى عمود‎ 
چ‎ grid قي‎ 


lnHented as contained 
in column Î 


Tent] 


BaselClass 
Laptiorn 


المطلوب . المسيطر الجديد سوف لن يظهر في ١ع١”ع1وعل ۴٥۲۳١‏ ولكنه يكون عاط1ئزر في ع1ا ١ا١.‏ 
كما في الشكل .)١- ٥(‏ 


نعمل خاصية ع١۲همء‏ بالنسبة إلى العمود مساوية إلى .۴.. 
نعمل خاصية ٠١۲٣ ٥٣٤١١1‏ إا بالنسبة للعمود إلى المسيطر الجديد الذي تمت إضافته. 
وإذا أردنا أن نحذف المسيطر الإضافي داخل عمود 14ع نتبع الخطوات التالية: - 
في مربع ظط٥‏ الموجود في sس0لہاW۷‏ ع)۲ممه۴ نختار المسيطر. 
نجعل شاشة النموذج في حالة ١۷ا٥۸‏ عن طريق ضغط الفأرة عليه. 
نضغط مفتاح عع[عل. 
ملاحظة: - إذا كان المسيطر المضاف هو ×80 0ط١۳٥٥‏ ولغرض إظهاره بأفضل صورة نغير الخصائص 
التالية بالنسبة إلى ×80 boصە€:‏ - 
BackStyle = 0‏ 
Margin = 0‏ 


SpecialEffect = 1 
BorderStyle = 0 
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جامعة الانبار 
AE‏ 


صديق قيس عبد الر من الدوسري 
ويبين الجد 


2 


كص 6114 : - 


Property 


The foreign key of the child table that 1s joined with the primary key of the 


CIEE parent table. 
Number of columns. If ColumnCount is set to - 1, the grid has as many 
ColumnCount columns as there are fields in the grid’s RecordSource. 


LinkMaster The parent table for child records displayed in the grid. 
RecordSource The data to be displayed in the grid. 


Where the data displayed in the grid comes from: 
RecordSourceType ja table. an alias. a query. or a table selected by the user in response to a 
prompt. 


- ويبين الجدول التالي أهم خصائص الأعمدة:‎ 
Property Description 
ControlSource The data to be displayed in the column. This is often a field in a table. 


If Sparse is set to true (.T.), controls in a grid are displayed as controls 
only when the cell in the column is selected. Other cells in the column 

Sparse display the underlying data value in a text box. Setting Sparse to true 
(.T.) allows faster repainting 1f a user is scrolling through a grid with a 
lot of displayed rows. 


Which control in the grid is active. The default is Text1, but if you add a 
control to the column, you can specify it as the CurrentControl. 


CurrentControl 
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- كلية الحاسوب 
DD‏ 


Menus And Toolbars design ٽlودأJ| تصميم القوائم وأشرطة‎ .٦ 


صديق قيس عبد الرحمر الدوسري 
0000000000000000 


القوائم (sئuا٣۷M6)‏ وأشرطة الأدوات (كإةط١ه١٠)‏ يقدمان طريق معالجة كفوء للمستخدم في السيطرة على إيعازات 
التطبيق . التصميم المناسب للقوائم وأشرطة الأدوات يوفران بيئة مناسبة للمستخدم بحيث لا يتضايق أو يمل عند 
استخدام التطبيق» ويفهم أسلوب التعامل مع التطبيق بسهولة ويسر . 


أ . إنشاء القوا 
معظم العمل الذي يتضمنه إنشاء القوائم يجري في مصمم القوائم (۲٥”عذوە(‏ uامM)»ء‏ حيث يتم إنشاء القوائم» 
القوائم الفرعية واختيارات القوائم. 
ويبين الشكل )١- ٦(‏ شاشة مصمم التو „(menu designer) pÛl‏ 


FZ Menu Designer - Menul FIEI Eî 


Prarmpt Result LIptioriz Menu level: 
Menu Bar 


Item 


Insert 


lser Bal. | 


WEEE | 
Preview | 


(Menu Designer) مÛlوقll شاشة مصمم‎ (١- ٦( الشكل‎ 


. Menu Designer ةشlژ‎ il تز¡ظھر‎ «Menu ونختار‎ New نختار‎ ۴٥ من قائمة‎ 


يتألف إ٥«عاومل‏ uا«عمص‏ من تلاثة أقسام رئيسية وهي: - 


اولا . ×0 ء1 تحتوي على الخيارات التالية: - 
Prompt .)۱(‏ : يدر ج فيه عنوjl „menu Bar ڍİ menu‏ 
Ru .)۲(‏ : يظهر فيه ×0ط 0ط ٥۳‏ فيه أربعة عناصر وهي : - 
(أ). رصع : - إذا تم اختيار هذا العنصر فيكتب في ×0ط ا×ع] المقاإبل الإيعاز المقتقرن بهذا 
الاختيار. 
(ب). مصعم ۴4 : - إذا تم اختيار هذا العنصر فيكتب في ×٥ط‏ {×ع) أسم 44م الذي سيظهر في برنامج 
القائمة )."p١.(‏ بعد عمل عأ4إممءم6 له. 
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| جامعة الانيار - كلية الحاسوب صديق قيس عبد الر من الدوسري 
إذا تم اختيار هذا العنصر فسيتحول ×٥ط‏ ا×ع) المقابل إلى ERS a DUO‏ 
وعند الضغط عليه نتحول إلى شاشة تصميم القائمة الفرعية (ويتغير ×0ط 0طهء في الجهة العلويية 
اليمنى من ١2ط‏ uمعص‏ إلى اسم الاختيار الحالي المراد عمل uا«عصطنء‏ له). 


(د). «i0اpه:‏ - هو عبارة عن ١٥0))ااط‏ عند الضغط عليه تظهر شاشة .Prompt option lawl‏ 


: Submenu )ج(.‎ 


ثانا . ×٥ط combo‏ اسمھا ۷e1عا‏ uرعص‏ تؤشر فيها مستوى ادع" الحالي (٣4ط‏ uصمص‏ أو اختيارات 


„(menu 


ثالثا . أربعة مسيطرات من نو ع ١اط‏ dأمجسصهء»‏ وهي كالآتي: - 
se۲ .)١(‏ : - لإضافة اختيار جديد إلى uارعص.‏ 


.Submenu لإضافة اختیار جدید إلى‎ - : sert Bar .)۲( 
„submenu ڍڪ‎ menu ja لحذف الاختیار‎ - : Delete .)۳( 


Preview .)٤(‏ : - لعرض ا1٥0‏ أثاء التصميم. 


ملاحظة: - العلامة |< قبل أي حرف من اسم الاختيار يجعل تحت الحرف خط ويمكن عمل ١1۷410اءج‏ لهذا 
الاختيار عن طريق ضغط هذا الحرف. والعلامة | - تفصل ٣ع¡‏ ١٣ع"‏ عن بعضها عن طريق رسم خط. 
قبل استخدام اع" في التطبيق يجب عمل ١٥1اة۲٥,ءع‏ له» وذلك عن طريق اختيار قائمة ۳8٥1‏ وثم 
اختيار ۵ا۲۵٥,معء‏ فتظهر شاشة ۲م٣إ٠۴۲‏ لخزن هذا امع" (بأي اسم يتم تحديده) ويخزن ملف التصميم 
بالاستطالة (.حصص)ء هذا الملف هو عبارة عن جدول يخزن فيه المعلومات عن 0811. وبعد خزن 0€11 
تظهر شاشة أخرى ام ,إ١٠۴۲‏ لعمل اماه إلى ملف بنفس اسم اصع" ولكن بالاستطالة (.۳"P۲)ء‏ ويحتوي 
هذا الملف على برنامج توليد ۸۷ع١.‏ 


أ . shortcut menus sli‏ 
تظهر كاطع ااءاإهطء عند ضغط الزر اأيمن للفأرة على اء٥زطه»‏ ويوفر طريقة سريعة لعرض الإجراءات 
والفعاليات التي تتعلق بهذا ٤ءء‏ [طه فقط. نستخدم ٥×۲١‏ اعuءزل‏ لإنشاء مثل هذه usا«ع"‏ وبعدها نربطهامع 
)ءeزbه‏ المطلوب. فمتلا يمكن عمل امعط اuاء)إ0طء‏ تحتوي عل الإيعازات اباء» إمهء» ماهم والتي تظهر عند 
ضغط الزر الأيمن للفأرة على عمود في أذإع. ولإنشاء مثل هذه كوuارعمص‏ نختار القائمة م[ا؟ وبعدها 16W‏ ثم 


menu‏ ونختار .shortcut‏ عملية إضافة كsصmع)1t menu‏ في shortcut menu‏ هي نفسها في 11ع"]. 
و لإضافة uارعص‏ {اhortcuء‏ إلى tععزطه»‏ نختار ٤ءع[طه»‏ وندخل إلى الصيغة المتعلقة بالحدث عناء ٤٣عا»‏ ونكتب 
الإيعاز التالي: - 


do menu_name.mpr 
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لي ر a‏ 


کک حیث name n‏ ا oul menu‏ ل ب» ویجب ب التأكد a‏ إضافة mbt extension‏ إلى 
الاسم. 
يمكن إضافة ٤اءا0۲طء‏ ١إد0طارمK‏ إلى اختيارات القوائم» وهي طريقة ضغط مفتاح معين بينمانكون مستمرين 
بالضغط على مفتاح آخر» والفرق بين حرف المعالجة (الحرف الذي يكون تحته خط( keyboard shortcut jung‏ 
هو أنه في الا٤0۲طء 02۲١‏ ارم نعالج الاختيار المطلوب دون الحاجة إلى إظهار القائمة المرتبط بها هذا الاختيار . 
ولإنشاء men‏ {uءhortء‏ نختار عنصر 11ع" المطلوب ونضغط في حقل ١٥امه‏ الخاص به فتظهر شاشة 
option‏ tاpصmتام.‏ وفي مربع 1٤ا14‏ رع نضغط مجمو عة المفاتيح المطلوبة لإنشاء هذا ألا٥٤0۲طء.‏ وفي مربع 
)×عt‏ رع نكتب العبارة التي نريد إظهارها جنب اختيار القائمة (عادة ما تكون هي نفسها ااع٤0۲طء).‏ 


ملاحظة: - [+1 ٥1۸‏ هو keyboard shortcut‏ غير مسموح باستخدامه له يغلق ×ط چ0اهنق في ۷۴۴ . 


ولغرض قاف عمل e۳‏ uا٫عص‏ معین إلا بشرط محدد يمكن استخدام مربع ٥١‏ مء الموجود في شاشة 
option‏ romptم‏ بعد ضغط ١٥1امه‏ لاختيار القائمة المطلوب» فتظهر لنا شاشة ۲ع ل1زاط ١10ءوعم×م.‏ كما في 
لشکل )۲١ ٦(‏ 


Skip For senpL?: 


Fields: Warlablezs: 


_alignment 
_box 
_indent 
_lmargin 
_padvarce 
_pagenn 
_Ppbpage 


¥ 


Frarn table: | 1 


الشكل ٦(‏ -۲) شاشة بناء التعابير 
إذا كان التعبیر نتیجته (.۴.) فإن اختيار القائمة يحصل له ۵ع1طھہ 8 أما إذا کان (.1.) فإن اختيار القائمة يحصل 
ذ4 Disabled‏ . 


ج . إنشاء أشرطة الأدواٽ Creating Toolbars‏ 
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| جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدو سري 
E: EDED 2‏ 
إذا كان التطبيق يحتوي على فعاليات قد تتكرر أثناء العمل يمكن إضافة شريط أدوات لعمل هذه الفعاليات» ولغفرض 
إنشاء ٣012م‏ يجب استخدام ھآ خاصة بهذا ٣2ط[0ه0).‏ 
نختار قائمة عاذ وتم عه ونختار sيهآء.‏ في مربع ع14۳ وھا نختار اسما لهذا sئهآء.‏ ومن مربع 01 Based‏ 
نختار إجط1هه۲ ليكون هو وها الأب. وفي مربع S0۲١ 1١‏ نطبع المكتبة (رإهإط11) المراد خزن ككها©C‏ 
الجديد فيهء أو نختار 0ا۳٥)‏ لاختيار مكتبة موجودة أصلا كما في الشكل .)١- ١(‏ فتظهر لنا شاشة تصميم يمكن 
در ج اءعزط0 فيها وكتابة ئلهطاعص للأحداث التي تقع على هذا ٤ءعزا0.‏ 

Llass Hame: [pining 

Based Un: | Toolbar >| 0 Cancel | 


Fram: 


Stare |r: | inyertary 2 | 


الشكل ٦(‏ -) شاشة تحديد صنف جديد 


Reports Designing ريرlقتll تصميم‎ . ۷ 
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هناك عدة طرق تستخدم لتصميم التقرير . وباستخدام مصمم التقارير report designe‏ أو منجم الثتقارير )0۲مre‏ 
4اا نستطيع إنشاء تقارير كفوءة وذات مظهر جيد وبأساليب عرض بيانات مختلفة. وفيما يلي الخطوط العامة 


أ ,. تحديد الخطوط العامة للتقرير 
قبل إنشاء التقرير نحدد الصيغة العامة للتقرير . فقد يكون التقرير بسيط ويشمل جدول واحد أو يكون التقرير معقدا 
ويحتوي على أكثر من جدول. ويبين الشكل (۷ )٠-‏ نماذج لبعض الصيغ العامة للتقارير . 


Column report Row report Ûne-to-man¥ Multi-column Label 
report report 


الشكل (۷ )١-‏ نماذج لبعض الصيغ العامة للتقارير 


الجدول التالي يوضح هذه النماذج أعلاه. 
Layout Type‏ 
Group/Total report‏ 


Column One record per row with fields placed horizontally across the page mne TEE 
Inventory 


Sales summary 


Row One column of records with fields placed vertically down the side 


: : Invoices 
One-to-many One record or one-to-many relationship 
More than one column of records with fields placed vertically down the Telephone directory 
Multi-column ٤ 
left margin Business cards 
Label More than one column of records with fields placed vertically down the Mailing labels 
left margin; printed on special paper Name tags 


ب. إنشاء التقارير 
يمکن إنشاء التقاریر في ۷۴۲۴ بثلاثة طرق: - 
اولا . إنشاء التقرير ڊبwlتخدpl .Report Wizard‏ 
ثانيا . إنشاء التقاریر بشکل سریع عن طریق 0۲مRe Quick)‏ . 
ثالثا . تحديث نقرير موجود أو إنشاء نتقرير عj‏ þ¦|رJı Report Designer‏ . 
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ج . استخدام Report Wizard‏ 
یمکن استخدام W1⁄۵۲۵‏ ۲۴0۲۲ في تصميم التقارير ومن ثم تعديل التصميم في "٤۲‏ عs1عd‏ )معا حیث يوفر )0۲مpع؟‏ 
14 الفقرات التالية: - 
.Report‏ 
One-to-Many‏ 
Label‏ 
Mail Merge‏ 


ملاحظة: - (الفقرتين الأخيرتين غير موجودة في نسخ تطبيق ۷۴۶ المتداولة حاليا). 
ولتصمیم التقریر نختار من قائمة ۴1٥‏ اختیار New‏ ومن .Report Wizard رlتخi laدعڊy . Report pû‏ 
کما ویمکن اختیار W1⁄2۲۵‏ 0۲۲م۲۴ من قائمة ءآامه)] واختيار 0۲۲مع۲»ءوبنفس الطريقة يمكن اختيار 1عطaا‏ و .Mail‏ 


د . تحديث محتويات التقارير 
إذا كان لدينا تقرير فارغ (مصمم عن طریق ٣٤۲‏ ع1وعل ٤إoمع)ء‏ أو w21۵‏ مصمم عن طریق w4۲4‏ 0۲۲ص۲ أو 
repo‏ ickاې»‏ فیمکن تحدیث محتویات التقریر عن طریق €۲ 5181ع 0 مع۲. 
في حزم (ئل٣مهط)‏ داخل إمnع¡des report‏ يمكن إضافة sامإا«هء‏ التي تسيطر على العناوين كاعطه[ء الحقول» 
والمتغيرات» وكذلك التعبيرات التي نرغب في طباعتها في التقرير. ولتحسين مظهر التقرير يمكن إدراج الخطوط والأشكال 
اة م ات كر قر اء وراج الور واكرن. 
يتم استخدام ما يسمى (ءل1هط) لتحديد محتويات كل صفحة» مجموعة»ء وبداية ونهاية التقرير . يمكن تغيير حجم كلمةط 
وإضافة كاهإا«هء» ونقلها من مكان إلى آخر وترتيب مواضعها في التقرير . والتقرير يحتوي على عدد من كل«هطاء ويبين 
الشكل (۷ -۲) بعض أنواع كلمهط التي يمكن إدراجها في ٤0۲مء۲.‏ 


Place controls for title, date, page 
number, or compary logo, and box Place Hate, page number 
arf out the title contents here. afd colurnn headings here. 


E Report Designer - Reportl FEI E 


a ez 
0 


اا | 


Place grouping field #& Page Header 


and separation 1 
line here. - 
#* aroup Header 1: 


û 


ea‏ ڪھ 
سالا 2 Place‏ 
ace date, pajê :‏ 
roup Footer 1:‏ &ھ nurmber, subtotal line,‏ 
subtotals and 0‏ 
descriptive text here. 1‏ 
\|Page Footer‏ # 


0 | 


STILE 


م ٣‏ ا 


Place Hata and descriptive Place “grand totals” text here, Place group totals and —Û 
text herge, — ‘Subtotal text here, 


الشكل (۷ -۲) بعض أنواع ءل« هط في التقارير 
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ا اا ار وري 


ويمكن أن يحتوي التقرير على عدد من الحزم (sلمهط‏ صدمع) ويبين الجدول التالي أنواع استخدامات كلمط. 


Use this band Use this command 
Title Choose Title/Summary from the Report menu. 


Page header Once per page Available by default. 


Choose Page Setup from the File menu and set Column 
Column header | Once per column 
Number greater than 1. 


Group header Once per group Choose Data Grouping from the Report menu. 


Detail band Available by default. 
Group footer Once per group Choose Data Grouping from the Report menu. 


Choose Page Setup from the File menu and set Column 
Column footer | Once per column 
Number greater than 1. 


Page footer Once per page Available by default. 
Summary Choose Title/Summary from the Report menu. 


ه . اضافة أت الت Report Control‏ 


يبين الجدول التالي أنواع كاه٣ا«ه)‏ التي يمكن إضافتها إلى التقرير. 
To display E this control‏ 


Table fields, variables, and other expressions 
Literal text 


Straight lines Line 


Boxes and borders 


Circles, ovals, boxes with rounded corners, and borders Rounded Rectangle 


Bitmaps or general fields Picture/OLE Bound 


و . تحديد مصادر بيانات التقرير 
يمكن إضافة مصادر البيانات إلى التقارير بسهولة عن طريق ۳۴١۲‏ ۸١١۷1۲١ء‏ هاهل الخاصة بالتقرير» حيث يمكن 
إضافة الجداول والمنظورات وترتيب هذه الجداول والمنظورات وفهرستها وحسب متطلبات التقرير . 
وتقوم ۲١١۸008٨۲‏ ۷1ء (ata‏ بإدارة مصادر البيانات في التقرير على النحو التالي: - 
فتح الجداول والمنظورات عند فتح أو تنفيذ التقارير 
التعامل مع البيانات المقترنة بالجداول والمنظورات. 
غلق الجداول عند انتهاء التقرير. 
ولإضافة جدول أو منظور إلى ٤۸عص٣تrإزہمء‏ dataء‏ من قائمة view‏ نختار data environmen‏ أو عن طریق 
نقر الزر الأيمن للفأرة ومن تم نختار ل۸ . 
ويتم التعامل مع ١١1ع١١١۷1۲١ءع‏ 4هل بنفس الطريقة عند تصميم النماذ ج من حيث الفهرسة والعلاقات ...الخ. 
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ز . إضافة مسيطرات الحقول 
يمكن ان يحتوي التقرير على كاهإا«مهء 14ء والتي تمثل قيم الحقول في جدول أو منظور» قيم المتغيرات» أو 
القيم الناتجة عن حسابات معينة. 
ولإضافة حقل موجود في جدول ضمن ٤١6١٥۷1۲١ء‏ اهل الخاصة بالتقريرء نقوم أولا بالدخول إلى شاشة اهل 
environ‏ ومن ثم نؤشر الجدول المطلوب والحقل المراد درجه في التقرير ونعمل له عuإل‏ إلى أن نصل 
بمؤشر الفأرة إلى الموقع المطلوب في مساحة التقرير ونعمل له ص٥۲ل‏ في ذلك الموقع. 
ويمكن إضافة هذا الحقل عن طريق 4۲طاهه) إممعذیمل اهمه أيضا. 
ولعمل هذا نتبع الخطوات التالية: - 

من report contro1 t)00o1ba۲‏ نضیف مسیطر 14ع]؟. 
بعد لإضافة المسيطر تظهر لنا شاشة 10۸ءءع]م×ءe‏ )معا فنختار ۸٥0))اط‏ بعد مربع e85101مex.‏ 
في مربع 14ع1٤‏ نعمل ععءناء عانم للحقل المطلوب. 


ج . إ¦ۈضlغة Label Control‏ 
يمكن إضافة 1٥ا12‏ لطبع التعبيرات الثابتة في التقرير مثل العناوين» عناوين الحقول» أو أي معلومات أخرى. 
ولإضافة مسيطر 1٥ط[‏ نتبع الخطوات التالية: - 
report controls toolbar ja‏ نختار .labe]l‏ 
من إع«عاوعل ۲إاممءء نضغط على المسيطر ثم نؤشر موقعه في التقرير ونكتب العبارة المطلوبة. 


ولتحديث 1٥طه1‏ موجود نؤشر على المسيطر 1عطه1 في ۲ھط01ه) report contr01‏ ومن ثم نؤۇشر على |‌bط1la‏ 
الفراة تة تدر ف غه التعتك. 


ط . إضافة حJa‏ عام (General Field)‏ 
يمكن إضافة حقل عام يحتوي على 01۴ في التقرير عن طريق ما يلي: - 
.Picture/OLE Bound رۉۇi report control toolbar ja‏ 
نعمل له عنل في الموقع المطلوب في التقرير فتظهر لنا الشاشة الموضحة بالشكل (۳-۷) وهي 


.report picture ةشlش‎ 


في مربع 1614 نطبع اسم الملف أو نضغط ١0ط‏ في نهاية مربع 14ء1؟ لاختيار الملف المطلوب. 
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ڪڪ ڪڪ EDED‏ 
Report Picture‏ 


Picture fram 


1 File: | 0 


Print when... | 


IF picture and frame are differant sizes 
fF Clip picture 
Scale picture, retain shape 


{” Scale picture, fill the frame 


7 Ubject Pastiar 


۴a‏ £ اس 
اھ 
Fiwed relative to top of band‏ * 


f Fiued relative Io bottom of band 


Û Center picture 


Lamment: 


report picture ةشlژ‎ ("- ۷) الشكل‎ 


ملاحظة: - يمكن عمل رمهء» الاء» و مایم لأي 01إ٤صهء‏ في ٤0۲مء»‏ حيث يمكن التعامل مع کائنات 0۲ص٥۲‏ 
مدل أي تطبیق آخر من تطبیقات sس0wلہW1‏ . 


. ترتیب ات الت 


نستطیع عمل ترتيب للمسيطرات (۲٣٥۳,ع1ا۸)‏ لكل مسيطر على حدة أو بالنسبة إلى مواقع المسيطرات الأخرى 
ويمكن عمل ذلك عن طريق ١2طا0ه)‏ ااهره[. كما موضح في الشكل (۷ .)٤-‏ حيث يمكن نقل 1١۲٣)٤«هء‏ إلى 
الیسار أو اليمين» توسيط 1١٥۲٤۸٠ء‏ إظهار ه امام »٥١٤۲01‏ آخر أو إخفاءه خلفه. 


5 


EH Report Designer - Reportl EE] 


س 
0 


To align all the controls to this EET 


control's left edge, choose 
Align Left Sides, iE 


[Report TEREESL 3 


[Rerort CDBAEEOL 2 م‎ 
Reporte Control 3 


E 


A | F 

OO 

8 
اداع کڪ 


To align all the controls to this control's left edge, 
press CTRL and choose Align Left Sides. 


Layout Toolbar -6ئ(‎ ۷) Jكشll‎ 
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بعد الانتهاء من تصميم الخطوط العامة للتقرير» نبدأً بتحديد مجموعات البيانات في التقرير. تتيح هذه العملية فصل بيانات 
كل مجموعة عن الأخرى وإظهار العناوين والخلاصات لكل مجموعة. 
عند عمل مجموعات» فإن كل مجمو عة سوف تمتلك 1e2‏ 0upاG‏ و اع۴00 حيث يمكن إضافة مسيطرات له. 
كما ويمكن أيضا تحديد خيارات أخرى لكل مجموعة وهي: - 
طبع العبارات في إءلةعط و إعاهه۴ لتعريف كل مجموعة. 
طبع كل مجموعة في صفحة منفصلة. 
إعادة تضفير عداد الصفحات عند طبع كل مجموعة في صفحة جديدة. 
كما ونستطيع إظهار البيانات وفق الترتيب المطلوب عن طريق فتح الجدول في بيئة بيانات التقرير على الفهرسة المطلوية. 
. إضافة عة مفردة 
التقرير ذو المجموعة المنفردة هو عبارة عن مستوى تجميع بيانات واحد» فمثلا إذا ردنا أن نطبع تقرير لطبع كل القيود 
لأفراد يعيشون في محافظة واحدة فنضع ٠٥ع‏ لكل محافظة (بشرط عمل فهرسة للجدول على المحافظة). 
ولإضافة مجموعة إلى التقرير نتبع ما يلي: - 
من قائمة 0۲۲ مم۸ نختار 0ata Grouping‏ فتظھر لنا شاشة ×0ط Data Grouping Diao‏ كما في 
الشكل (۷ .)٥-‏ 


Data Grouping E 


Lancel | 


Lıp E#presslons: Enter a expression . 


arn 


Select to build an expreszlon . 


Insert | 
Delete | 


arouıp properties 


VT Ta I a ELI 
TT Start each group on a Hew page 


[Reset page number ta 1 for each group 


TT Beprint group header on each page 


Start group on new page when less than [o.oono ات‎ 


اكل )¥ -5°( Data Grouping Dialog Box‏ 
في مربع ص6۲01 نطبع التعبير المطلوب. أو نضغط ۸٥0ا†‏ ں8 للدخول إلى شlشة Expression Builder‏ . 
في المساحة Group Properties‏ نحدد خیارات group‏ . 


S1 Belect to prevent ldouu or 
orphan group header lines. 


بعد إنشاء 107ءوعإم×ع ننقل أحد sإcontro‏ إلى »bands‏ وعادة يكون ١١اه‏ المستخدم لعمل p1١‏ g۲01ء‏ 
حيث يتم نقله Group Header Band yl Detail Band ja‏ . 


7-۳ 


جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدوسري 


EEOC 


م . إضافة عمذم0uاG (ata‏ متعددة 
يمكن عمل ۲١‏ مجموعة (ع«امuاهاع‏ aاهل)‏ لكل تقرير . 
ولإضافة مااع عامناااص نتبع الخطوات التالية: - 


من قائمة 0۲۲ص۲ نختار Data Grouping‏ الشکل (۷ .)٥-‏ 

في مربع أول طuهإ6‏ نطبع 10۸ءءعإم×ءع أو نضغط ١0ط‏ للدخول في .expression builder‏ 
في Group Proper) es‏ نختار sعrtiممoا۴‏ المطلوبة. 

نختار 1,٥۲٤‏ ونعيد الخطوتين السابقتين لكل pاه۲0ع‏ . 


" » 0 ااتف 
. 


رر عن رن اتان او لر ف فرك ون ك ۷ هرا ج رر اكات ا ا 


Title Summary bands 
Control formatting Grouping data 


Report Designer - eportl - Microsoft Yisual FoxPro BEI EH 
Page setup 


Print FT Bg File Edt view Format Tools Frogran Report window Help 


Data envirortnert Û 
Previn 


) ٤ ٤ ٤ ` aaa: 


: Heport Controls لخا‎ Color PaletEa || 


[F Amr lal ol) 


#& Page Footer 


SEE 
امه" المتاحة لتحسين مظهر التقرير‎ )٠- ۷( الشكل‎ 
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مدق فر ا ۴ا 


عند التخطيط لإنشاء التقرير يجب مسبقا معرفة كيفية ظهور الصفحة من حيث الحواشي» نوع الورقة وحجمها 
وارتفاع كل حزمة (1١ةط)‏ وتفاصيل المسيطرات في التقرير . 

ولتحديد الهامش الأيسر للتقریر» نختار من قائمة ۴٥‏ اختيار Setup‏ معٍ۴a.‏ فتظهر lلناشlشغة Page Setup‏ 
Di08 Box‏ كما في الشکل (۷ -۷). 


Page layout: 


Lolmna 
Murmber: 1 ات‎ 
width: BOOL=S 


Spacing: j HE 


Lancel | 
Print Setup... | 


Print order: 


| 3 
Left margin: [o.00 س‎ left margin here. 


Dimensions: Inches 


Print area 


* Printable page 
hole page 


See the charges to your layout here. 


Page Setup ةشlژ‎ (۷- ۷) الشكل‎ 


وأتحديد الهامش»› ندخل الرقم المطلوب للهامش في مربع «Left Margin‏ فتتغير صورة الصفحة لإظهار الهامش 
الجديد. وفي مربع طنا٥؟‏ إ۴ نختار حجم الورقة المطلوب من قائمة ع81z.‏ و لاختيار اتجاه الورقة (عممهءءل١ه1‏ 
أو )Prtra‏ نضغط على ںام ٤«ذإ۴‏ ونختار الخيار المطلوب من مساحة .Orientati0n‏ 


. تحديد صيغة الحقول وا ات 
بعد إدراج الحقول والمسيطرات يمكن تغيير صيغتها ونوع البيانات التي يمكن طبعهاء حيث إن البيانات قد تكون 
Numeric Character‏ أو .Dte‏ وكل نوع من هذه الأنواع لها الصيغ الخاصة بها. 
ولتحديد صيغة Report Expression Dialog Box lil رqظ¡ت . Field ule Double Click طخiضi Field‏ 
فنضغط ۸٥))ںاط‏ بعد مربع ۴٥۲۳٣۹٤‏ . فتظھر لنا شاشة ×٥ط‏ ع٥اھi٥ ۴٥۲٣۵٤‏ کما في الشکل (۷ -۸). ومن مربع 
۴ نختار نوع البيانات لهذا الحقل أو المسيطر» فتظهر في مساحة ع١1اال8‏ الخيارات المتاحة للصيغ تبعا 
لنوع البيانات. وبعدها نختار موقع الطبع وخيارات الصيغة. 
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صديق قير ا وري 


Enter template characters and codes here. 


Format: 
iE < ڪڪ‎ 
Lancel | 


Select a data type here. ## Character FÊ Numeric 1. Date 


Editing optianz 
IT To upper case I Left justi 
Select field 

control forrnatting 
options here . 


I lgnare input mask. E N 
` SET DATE format TEE N 
T British date 


الشكل (۷ -۸) شاشة تحديد صيغ ظهور البيانات في التقرير 


ف. تغبير ill¡ط Changing Fonts‏ 
يمكن تغيير حجم الخط ونوعه للحقول والعناوين وذلك عن طريق تأشير المسيطر المطلوب تغيير خطه»ء ومن قائمة 
Format‏ نختار ۴0٤‏ فتظهر لنا شاشة ×80 ۴٥١ i1٥0‏ فنختار منها نو ع الخط وحجمه وطبيعة الخط (ل801» 
tac‏ ...الخ). ولتغییر (efu ۴٥۸٤‏ للتقریر نختار من قائمة ۲٤0۲م۸e‏ اختیار ۴٥۸٤‏ tاau؟Def‏ ومن تم نختار 

نوع وحجم الخط المطلوب لأن يكون ۴٥٣٤‏ اسهم( لهذا التقرير . 


. إضافة الخطوط و المستطيلات والدو ا 
يمكن إضافة الخطوط والأشكال الهندسية إلى التفرير لفصل وترتيب أجزاء التقرير. ويمكن اختيار الأشكال الهندسية 
من aط01هt‏ sاContro‏ eportا»‏ عن طریق اختیار أحد ١١‏ ٥اط‏ الخاصة بالرسم. 
عند اختيار المستطيل أو الدائرةء فإننا وبمجرد عمل )نا٣‏ ماطاسuه‏ عليه نستطيع تغيير خوا الشكل بعد ظهور 
شاشة Round Rectangular‏ كما في الشکل (۷ -۹) عند الضغط على Rectangula1/Line ةشlژ وİ circle‏ عند 
اف حل ممل ر غ 
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Round Rectangle E 


se 


Dk 
E د‎ 
Hhonze ã zyle for the Object position 
rectangle’ corners. 
` Float 


ا 
dl f* Fix relative to top of band‏ 


1” Fi relative ta bottom af band 


Stretch downwards 


fF No stretch 
t Stretch relative to tallest object in group 


{” Stretch relatiwe ta height of band 


lick here to control 
printing. 


Print when... | 


Laomrment: 


الشكJ‏ )۷ -4( ژlڎة Round Rectangular‏ 
۳ .تة 0 . ع الخطوط للأشكاز 


يمكن تغيير عرض الخط أو نوعه للأشكال الهندسية المختلفة في التقرير عن طريق قائمة ۴٥۲۳۹۲‏ واختيار ۸ء۴» 
ومن القائمة الفرعية التي تظهر نختار النوع والحجم المناسب للخط. 
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EEE ا‎ E E EEE 
uery and VIew Desl?nInېg‎ تIررظطنملاو صميم الاسدفسارات‎ 


عند استخدام VFP‏ یمکن إنشاء الاستفسارات أعدد من الجداول والمنظورات»› وتجميع البيانات ومن قواعد محلية أو قواعد بعيدة 
في منظورات داخل قاعدة البيانات. وإمكانية إنشاء الاستفسارات مفيدة جدا في أنظمة إدارة قواعد البيانات وخاصة إذا ردنا 
تجميع البيانات من أكثر من جدول عن طريق ترابط العلاقات بينها. 


أ . الاستفسار باستخدام جداول ومنظورات متعددة 
إذا أردنا معالجة البيانات في أكثر من جدول أو منظورء فنقوم أولا بإضافتها إلى الاستفسار ومن ثم ربطها («هز) عن طريق 
الحقول المشتركة بينها. كما في الشكل .)١٠۸(‏ 
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cust_id 0 
company 
contact 


title 
country 


Remote Wien 


laneouıs | 


ed fields: 

Remote_customer. address & 
Remote_custorner. cily 
Remote_custormer.regqion 
Remote_customer.postalci 
Remote_custormer. country 


EE | 
BENE | 


er.makordam: nT 


Fieı Er. ordam 
Functions and expressions: 
| ا‎ Properties | 


الشكل (۸ )١-‏ شاشة مصمم المنظورات 


إذا استخدمنا قاعدة بيانات تحتوي على علاقات ثابتة بين الجداول فإن ۷۴۴ سیستخدم هذه العلاقات كعلاقات ربط بديهية 
(1n5ەJ‏ tاuةDef).‏ ولإضافة جدول أو منظور إلى الاستفسار فيجب أولا فتح قاعدة البيانات Query Desig"€r jg‏ 
1001a‏ نختار م121 .A۸d4‏ ومن مربع A44 آabاe Or View‏ نختار قاعدة البيانات المطلوبة ونختار الجدول أو 
المنظور المطلوب درجه في الاستفسار» أو نختار ١طا0‏ لتحديد جدول حر (ع1طھt (free‏ . 


ب .ا ة اختيار القيود باستخدام كرأم 
عند استخدام جداول متعددة في الاستفسار فإن طريفة تحديد السيطرة على القيود واختيارها تتم من خلال استخدام 
nsەز.‏ وباستخدام ×0 چەاھiل condition‏ inەز‏ يمكن تغيير نوع [٥1١‏ بين جدولين» يظهر ١1٥إ‏ بصورة 


أوتوماتيكية عند إضافة الجداول» كما ويمكن إنشاء s«زهز‏ عن طريق عمل علإل بين الحقول في 
»guery designer‏ أو بالضغط على Ad Joi" Butt01‏ كما في الشکل (۸ ۲۰). 


۸7-5۸] 


صديق قيس عبد الر من الدوسري 
DEDEDE‏ 


DD E E E E EEE 
Join Condition Eî 


| Urders.cusk_id 1 Lustomer.cusl_id 


Left jain Bight jain 1 Full join 


Lreake a result sel that incl4des only the Drders records thal match 
Lustomer records. 


join condition الشكل (۸ -( شاش‎ 


وبعد إضافة «ذهز أو تحديث ١ه[‏ موجود (عن طريق عمل نا٣‏ عاطاuه0)ء‏ نستطيع اختيار نوع ١1ز‏ لتوسيع 
حجم النتائج أو تضيقها. وأسهل طريقة لإنشاء ”ەز هو عن طريق استخدIم .join condition dialog box‏ 
ولإنشاء ١0ز‏ بين جدولين نتبع ما يلي: - 

أف الور لن اشقا 

. Add Join رlتخi‎ query designer toolbar ja 

من مربع ١٥1انلرمء‏ «ذمز نختار حقول الربط (مع ملاحظة أن الحقول يجب أن تكون من نفس نوع البيانات 
ولها نفس الحجم). 

بعدها نختار نوع «إهز» والربط على عدة أنواع» ويبين الجدول التالي أنواع «ذەز بین جداول ۷۴۲ . 


To retrieve... Use... 
Only records from both tables that match the join criteria, the most common type of . 
join ner Join 
All records from the table on the left side of the join criteria and only records that 
match the join criteria from the table on the right side of the join criteria 
All records from the table on the right side of the join criteria and only records that 
match the join criteria from the table on the left side of the join criteria 


All records from both tables whether or not they match the join criteria Full Join 


ج . استخدام جداول متعددة في منظورات 
يمكن أيضا ربط جدولين أو أكثر من ءعاطها اهءه1 من خلال sسعا۷‏ اةءه[1. وطريقة المعالجة تشبه تماما طريقة 
مغاتة الارن اشد رة اة فن المخاضرةا ركن اتد وار تكف فا اة أخرى همك روفي 


خاصية إمكانية تحديث جدول مصدر بيانات سع۷. أي أنه إذا أنشأنا سعذ۷ لجدول موجود في قاعدة البيانات 
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ديق قير ر الدوسري 


١ vie a ba ۴‏ المتو لدة ew‏ و في شاشة استعر اض بیانات Oe‏ قمنا بتخ ديت ل فإن 
البيانات في الجدول المصدر سوف تتغير أيضا. 

وین لشکل (۳۸) ودج لبط جدارل ن طري إنشاء غا 

ولربط الجداول في wع‏ اہ نختار ع1ط2 1 ل۸ في إneعDesi View‏ ومن ثم نختار Add [in‏ نغیر ١n‏ ەز 
ئconditi‏ كما نشاء ونختار )0 . 

وإذا أردنا أن نعمل ا2ء لتحديث مصدر البيانات نختlر‏ bؤTa «Update Criteria‏ وعدا نختlر SQL Send‏ 
updates‏ . 


ملاحظة: - لعمل 1۷اه إلى sعاةلمu SQ‏ 4ء يجب أولا تحديد أحد الحقول في أحد الجداول ليكون رع 
Field‏ . 
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order_id 
cuslk_id 
emp_id 


tD_namE 
to_addrezs 


4 


: Miscellaneous | 


Table: SAL WHERE clause includes 
Customer. cust_id f Kev fields only 
Custamer.compahy f Key and updatable fizlds 
Reset Key | Customer.contact fF kev and modified fields 


Lustormer. title TE EEN aI mE Slap 


Customer.addrezs‏ | اھ عادلملا 


lIpdate zing 
Lust 2ik t SQL DELETE then INSERT 
IW Send SAL updates E ۳ 2 E 
Lustamer.regior f SAL UPDATE 


Wpdatez are sent to the source tables. 


الشکل (۸ -۳) ربط الجداول باستخدام W‏ ع۷ 


د . إضlغة SQL-Statement مlدختwlڊ Query‏ 
عند إضافة كعإمں إلى التطبيق فإننا نستطيع جمع البيانات من مصادر بيانات متعددة ومختلفةء بالإضافة إلى عمل 
۳١‏ للبيانات» ترتيب البيانات» ...الخ» كل هذا باستخدام ا1-8Q٣5S8]8.‏ وباستخدام هذا الإيعاز فإننا سنمتلك 


السيطرة الكاملة على البيانات الناتجة وعلى موقع إخراج هذه النتائج. 
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جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدوسري 


وفيما يلي بعض الأمثلة على استخدام :SQ1-Stat eme‏ - 


SELECT ‘+ * 
FROM tastrade!customer: 
WHERE customer. country = "Iraq" 


في هذا المتال يتم اختيار كل القيود من جدول اسمه 0٥١‏ 0ءء موجود في قاعدة بيانات اسمها ه24 ل)ءع) للقيود التي 
فيها قيمة خاصية الدولة فيها مساوية إلى 1۲4. ومما يجدر بالملاحظة في المثال أعلاه هو فصل اسم القاعدة عن اسم 
الجدول بعلامة (!). 


SELECT TOP 10:* 

FROM testdata!customer INNER JOIN testdata!orders: 
ON Customer. cust id = Orders.cust id; 

GROUP BY Customer. cust id: 

ORDER BY Orders.order amt DESC 


في المثال أعلاه نقوم باختيار أول عشرة زبائن لجدول إعص0ناء في قاعدة a٤ةل)ءع)‏ مرتبين حسب أعلى قيمة 
طلب (حقل )٥۲١٥۲_۵۳٤‏ الموجود في جدول الربط ١۲ع‏ ل۲٥‏ في نفس القاعدة» ونستخدم 8 6۸00۴ لحقل 
cus‏ في جدول 0۳۴۲ء لإظهار طلب واحد لكل زبون فقط. 


ه .تحديد وجهة الإخراج لنتائج الاستفسار 
الإخراج بالنسبة إلى كعإامuي.‏ 


To send results to this Ne 


destination 

Separate table INTO TABLE [table name( 
Array INTO ARRAY [Array namel 
Temporary table INTO CURSOR [cursor name] 
Active window TO SCREEN 


The default if no other destination is 
specified. 


Browse window 


لتحديد نوع الإخراج بجدول نضيف N10‏ إلى 5Q1‏ كما في المثال التالي: - 
SELECT *;‏ 
FROM tastrade !customer ;‏ 


WHERE customer.country = "Iraq" ; 
INTO TABLE mytable 
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حامعة الانبار - كلية الجحاسوب 


والمثال التالي يبين وجهة الإخراج إلى A۲۲۵‏ 


صديق قيس عبد الرحمن الدوسري 


SELECT * ; 

FROM tastrade !customer ; 

WHERE customer.country = "Iraq" ; 

INTO ARRAY aMyArray 

والمثال التالي يبين وجهة الإخراج إلى 0۲80۲ €: - 

SELECT * ; 

FROM tastrade !customer ; 

WHERE customer.country = "Iraq" ; 

INTO CURSOR mycursor 


- يبين المثال التالي كيفية إظهار نتائج الاستفسار في نقرير:‎ 
SELECT * ; 
FROM tastrade !customer ; 
WHERE customer.country = "Iraq" ; 
GROUP BY customer.region ; 
ORDER BY customer.postal_code, customer.company_name ; 
INTO CURSOR MyCursor 
REPORT FORM MYREPORT.FRX 


ملاحظة: - یمکن إنشاء رامد ا2 ssهr€‏ (یشبه spread shee‏ في )8×xce1‏ وكذلك Query‏ 41ا6 باستخدام 
Query Wizard‏ . 
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جامعة الانبار - كلية الحاسوب 


صديق قيس عبد الرحمن الدوسري 


يمكن بناء تطبيقات 4ع)1ءع1إ0-اءع[طه و »event-driven‏ على شكل عناصر منفصلة وكل على حدة ممايسهل 
عملية فحص هذه التطبيقات وتحسين أدائها. وبعد بناء كل هذه العناصر نستطيع جمعها بشكل موحد في تطبيق واحد»ء 
هذا التطبيق يجمع كل أجزاء التطبيق في تطبيق واحد مما يسهل علينا العمل في توزيع التطبيق على المستخدمين 
بشکل سهل و كفو ء. 

عادة ما يتألف تطبيق ۷۴۴ من قائمة رئيسية للنظام (أو نموذج رئيسي للنظام) وعدد من النماذج لإدخال البيانات أو 
عرضها وعدد من التقارير التي تتيح للمستخدم استعادة البيانات بأشكال مختلفة» وبعض البرامج التي تضمن تكاملية 
البيانات . 

وعند البدء في بناء هيكل التطبيق يجب ملاحظة النقاط التالية والتأكيد عليها: - 

أ . تحديد نقطة البدء عند تنفيذ التطبيق . 

ب . تحمیل بیئة التطبیق (٤1ع‏ ۳ .)٤۸۷1۲0۸‏ 

ج . عرض واجهة التطبيق الرئيسية. 

د . السيطرة على دورة الأحداث .(Events L00p(‏ 

ه. استرجاع البيئة الأساسية عند الخروج من التطبيق. 

و . بناء التطبيق من مشروع. 


أ . تحديد نقطة البدء في التطبيق 
يتم ربط كل جزء من أجزاء التطبيق مع الجزء المتعلق به وتحدد النقطة الرئيسية من خلال تحديد الملمف الرئيسي 
للتنفيذ (عاا؟ «نهط). هذا الملف الرئيسي يكون هو نقطة البدء عند تنفيذ التطبيق وقد يتكون من برنامج أو نموذج» 
وعندما نفد ۷۴۴ التطبيق الخاص بنا فإنه يقوم بتحميل هذا الملف في البدايةء ليقوم هذا الملف الرئيسي بتدفيذ بقية 
أجزاء التطبيق . وكل تطبيق يجب أن يحتوي على ملف رئيسي وعادة ما يكون عبارة عن برنامج» كماويمكن 
ادام تمودڈج كملف رئيشي :يحوي على عاضر البر امح الزئي سي مها إذآ كم بنا التطبيق باتهام 
Wiad‏ icationاApp‏ فسوف يتيح لنا أن نعرف الملف الرئيسي للتطبيق» كما ويمكن لنا أن نقوم بتسمية أو تغيير 
الملف الرئيسي وفقا لخصوصية ونو ع التطبيق. 
ولغرض تحديد نقطة البدء للتطبيق نتبع ما يلي: - 

في مدير المشروع (۴۲ع ٥۲ N2"‏ ز٥۴۲)‏ نحدد الملف» كما في الشکل .)١- ٩(‏ 

من قائمة اءعزهإم نختار «iة‏ 561 أو عن طريق ضغط الزر الأيمن للفأرة على الملف المطلوب. 
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صديق قير ا ا 
کک ملاحظة: - ET‏ نلف ار نے ان کرونه ستصیے اهال ول الملف إلى" eid oily‏ 
ationاmpiصدء‏ للتطبيق. مع العلم أن كل تطبيق يوجد فيه ملف رئيسي واحد فقط, 


2Ë 4 Documents 
E-WF Class Libraries 
The application 


main file appears 
in bold. 


APFl Libraries 
i. Applications HEME 1 
ERE Other 7 | 


Lieseriptian: 
Path: 


المهمة الأولى التي يجب أن يتضمنها عمل الملف الرئيسي هو تحديد وتحميل بيئة التطبيق. البيئة البديهية للتطبيق 
يولد مجموعة معينة من إیعازات 1آ8؟ و متغيرات النظام عند تحمیل ۷۴۴ . على أية حال فإن هذه التحديدات 
قد تكون غير ملائمة للتطبيق الخاص بنا ويجب أن نغيرها . ولغرض معرفة البيئة الحالية للتطبيق نتبع ما يلي: - 

من قائمة 1٥01‏ نختار 10”8امOp.‏ 

نضغط مفتاح S۲‏ مع الضغط على اختیار 0ء فیقوم ۷۴۴ بعرض بيئة S٤٣‏ في 14 C0٣1٣‏ 
Window‏ . 


في بيئة التطبيق يمكن تحديد مواصفات التطبيق ودر ج الفعاليات التالية فيه: - 
تحديد المتغيرات . 
تحديد المسار البديهي .(Default Pa)1(‏ 
فتح قواعد البيانات الخاصة بالتطبيق. 
تحديد المكتبات الخارجية وملفات الإجراءات. 


ملاحظة: - - قد تكون واحدة من الأفكار الجيدة هي في خزن التحديدات البديهية التابعمة إلى ۷۴۲ في برنامج أو 
متغيرات من نو ع cااطاں٣‏ وذلك لغرض استعادتھها بعد الانتهاء من التطبیق الخاص بنا والرجوع إلى ۷٣۴۲۶‏ . 
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جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدوسري 


- ج . عرض واجهة التطبيق الرئيسية 

قد تكون واجهة المستخدم الرئيسية هي عبارة عن قائمة أو نموذج أو أي عنصر مرئي آخرء حتى ولو كان التطبييق 
يعرض شاشة دخول إلى النظام (”ع٠إءء‏ ١٠ع٠!1)‏ قبل عرض واجهة الاستخدام الرئيسية. يمكن عرض الواجهة 
الرئيسية عن طريق كتابة الإيعاز هل في برنامج نه" إذا كانت الواجهة عبارة عن برنامج» أو ۲ه 0ل إذا كانت 


الواجهة عبارة عن نموذج. 


بعد تحديد البيئة وعرض واجهة التطبيق الرئيسيةء يجب التهيؤ لتحديد دورة الأحداث في انتظار تدخل المستخدم 
(صinteracti0 .)user‏ ويتم السيطرة على دورة الأحداث من خلال الإیعاز N۸842 ٤۷٤×158‏ والتي تسبب في 
بدء ۷۴۴ في معالجة الأحداث من قبل المستخدم (متثل عمل عءاء» أو ضغط مفتاح في لوحة المفاتيح). 
من المهم جدا وضع إیعاز ٤۷٤×138‏ ۸45 في الموقع الصحيح من الملف الرئيسي» وذلك لأن كل المعالجات 
تتوقف من لحظة كتابة الإيعاز لحين الوصول إلى الإيعاز المعاكس والذي هر .C1٤8۸۸ ٤۷ ٤۸×18‏ ولعل أفضل 
موقع له هو في نهاية البرنامج الرئيسي» مع ملاحظة أنه إذا لم نكتب هذا الإيعاز فإن التطبيق سوف يعود مرة ثانيية 
إلى نظام التشغيل بعد تتفيذه مباشرة. وبعد البدء في دورة الأحداث فإن التطبيق سوف يكون تحت سيطرة الواجهة 
الرئيسية للتطبيق . والمثال التالي يوضح كتابة هذا الإيعاز في الملف الرئيسي للتطبيق: - 
Do Form Startup‏ 
Read Events‏ 


وبالمقابل إذا أردنا أن نقطع دورة الأحداث فإننا نستخدم إيعاز CLEAR E۷ EN1S‏ من أحد اختیارات Meu‏ أو 
كاستجابة لحدث زاء على ١٥ا8‏ في النموذج الرئيسي. مع التأكيد على وجود إيعاز قطع دورة الأحداث قبل 
كتابة إيعاز بدء دورة الأحداث لمنع التطبيق من الدخول في دورة غير منتهية (0pه1]0‏ عt¡ہ۴ہ1).‏ 


ه. استرجاع البيئة الأساسية 

من الأمور المهمة هي استعادة البيئة الأساسية لتطبيق ۷۴۴ بعد الانتهاء من التطبيق الخاص بنا. ويمكن استعادة هذه 
البيئة إذا كان هناك خزن مسبق لقيم S٤1‏ سواء في متغيرات من نوع ناطان۴ أو في برنامج فرعي محدد فإننا 
سنقوم بتحميل هذا البرنامج أو استعادة قيم المتغيرات قبل الخروج من التطبيق ويفضل ان يتم استدعاءها من برنامج 
رئيسي . يبين الجدول التالي أهم الأجزاء التي يمكن أن يتضمنها البرنامج الرئيسي: - 


Code 
DO SETUP.PRG Call program to set up environment (store values in public variables) 


DO MAINMENU.MPR Display menu as initial interface 
Or Or 
DO FORM STARTUP.SCX | Display form as initial interface 


Establish event loop. A different program (such as Mainmenu.mpr must 
issue a CLEAR EVENTS command 


DO CLEANUP.PRG Restore environment before quitting 


READ EVENTS 
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. بناء التطبيق من مشرو ء 
الخطوة الأخيرة في عمل ١0اةازمهء‏ لمشروع هو بناء التطبيق الخاص به. والنتيجة النهائية لهذه العملية هي 
عبارة عن ملف واحد يحتوي على جميع ملفات المشروع» ويمكن نقل قاعدة البيانات والجداول مع التطبيق لغرض 
استخدامها من قبل المستفيد . ولغرض فحص المشروع» نختار 1اط من eعaمھصہ‏ اءعزه۲م ومن تم نختار 
project‏ dاrebui‏ من شاشة s«ەتامە‏ 1اط التي ستظهر لاحقا. 
ولغرض بناء التطبيق من المشرgع‏ iختlر Build Application رlتخi pö jمو «project manager ja Build‏ 
من شاشة «٠0نامه‏ لاناط. فيتولد ملف التطبيق من نوع (.مم) والذي يمكن نقله (مع البيانات) إلى حاسبات 
المستخدمین (بشرط وجود تطبیق ۷۴۲۴ على هذه الحاسبات). 
ولغرض بناء تطبيق تنفيذي (ء1طھاںءم×ع) نختار Bui]d‏ من project manage‏ ومن Build رlتخi oÛû‏ 
Executable‏ من شاشة ء«منامه 4انسط. فيتولد ملف التطبيق التنفيذي من نوع (.٥×ء)‏ والذي يمكن نقه (مع 
البيانات) إلى حاسبات المستخدمين (ولا يشترط في هذه الحالة وجود تطبيق ۷۴۴ على هذه الحاسبات). 


تنبيه: - في حالة نقل تطبيق تنفيذي )١×٥.(‏ إلى حاسبة لا تحتوي على التطبیق ۷۴۴ فيجب نقل ملفات معينة 
موجودة في الحاسبة التي تم بناء التطبيق عليها وبالتحديد في المسار التالي: - 
\..windows\system‏ 
وهذه الملفات من نو ع 1a ۲ay‏ )من عنصهمر( (.111) وهي الملفات التالية: - 
vbame.dll‏ 


vfp6r.dll 
vfp6renu.dll 


ولضمان عد حصول أي خطأً في التنفيذ يفضل نقل الملف ٥×ع.«‏ ٠6۲ص۷‏ الموجود في نفس المسار أعلاه. 
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صديق قيس عبد الرحمن الدوسري 


بالنسبة لكل مطوري برامج ۷۴۶ يجب تبني مفهوم معالجة الاستخدام المتعدد والذي ينشاً من خلال تعامل عدد من 
المستفيدين عبر شبكة حاسبات مع البيانات الموجودة في قاعدة بيانات معينة. والتعبير الأكاديمي لهذه العمليية هو 
Concurrency Control‏ وذلك لان المشكلة تحدث كنتيجة لمعالجة متزامنة للبيانات. والتداخل الذي يحدث هو أن 
مستخدمين أو أكثر يحاولون في نفس الوقت معالجة نفس البيانات. يوفر ۷۴۴ تقنيات جيدة لمعالجة تداخل الاستخدام 
المتعدد» وكذلك يوفر إستراتيجيات معالجة جداول منفردة (sعلمص‏ ع١1إء؟8uf)‏ وإستراتيجيات معالجة جداول متعددة 


„(Transaction processing) 


أ . مفاهيم الاستخدام lلnتعدد (Concepts of Multi-User)‏ 
إذا كان لدينا شبكة محلية 14١‏ أو شبكات ٥١ه1")۲‏ و طا۷6» ففي بعض الأحيان قد يدخل أكثر من مستفيد إلى 
البيانات لغرض تحديثهاء وقد يكون من محاسن الصدف عدم حدوتث هذا التداخل» إلا أن احتمالية حدوث هذا التداخل 
تتزايد بازدياد عدد المستخدمين للنظام» إذا لم نرغب أن نترك الأمر لمشيئة الصدف فيجب علينا توفير المعالجة 

المتاة لمل هذ د الحالات من التاخل: 

معالجة تداخل الاستخدام المتعدد في ۷۴۴ یتم عن طریق استخدام عدد من إیعازات S81‏ وعدد من إيعازات 
0. عملية القفل (ع«)ءم1) توفر للمستخدم عملية منع المستخدمين الآخرين من تحديث البيانات التي يتم 
معالجتها من قبل المستخدم الذي يقوم بعملية ع«i)ء1.‏ وقد يكون من الأمور المريحة بالنسبة لمطوري برامج 
من أن هذه الحلول لمعالجة الاستخدام المتعدد تحدث بصورة أوتوماتيكية من قبل التطبيق بدون الحاجة لكتاإبة 
الإيعازات لحل هذه التداخلات. في تطبيق ۷۴۴ تتقوفر بعمض تصرفات القفل البديهية ( اإuه5e۴‏ 
Behavior‏ ع0ckinا)‏ والتي تتطلب عبارات برمجية قليلة جداء ویقوم ۷۳۴ بمعالجة حالات التداخل وإرسال 
الرسائل (كءعهءءه) إلى المستخدمين. ولكن لا وجود لاستراتيجية موحدة لمعالجة كل حالات التداخل التي تحدثء 
لذلك يجب الإلمام بكل الإيعازات الخاصة بهذا المجال والاستراتيجيات المتوفرة في ۷۴۲ . 


هناك على الأقل ثلاث حالات من حالات التداخل بين المستخدمين وهي: - 


اولا . Edit Conf‏ (تداخل التحديث): - وهي الحالة التي تحدث عند محاولة أكثر من مستخدم من الدخول 
على البيانات لغرض التحديث» السؤال هنا هل نريد أن يقوم كل المستخدمين بعملية تحديث البيانات في نفس 
الوقت أو نسمح لمستخدم واحد من تحديث البيانات تاركا المستخدمين الآخرين في انتظار دورهم بعد انتهاء هذا 
المستخدم من عملية التحديث. 

ثانيا . s٤‌ناگره€‏ رامس (تداخل الاستفسار): - هذه الحالة تحدث عندما ينفذ أحد المستخدمين استفسارا أو 
تقريرا يأخذ فترة زمنية طويلة نسبياء وقد يكون نوع الاستفسار أو التقرير هو من الأنواع التي تتطلب تبات 
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صديق قيس عبد الرحمن الدوسري 
البيانات في الجداول المتعلفة» فإذا سمحنا لبقية المستخدمين من معالجة الجداول الداخلة في الاستفسار او 
فإنه يمكن حدوث تغيير في قيم بعض البيانات مسببة حدوث أخطاء في النتائج. 


ثالثا . Maintenance Conflicts‏ (تداخل الصيانة): - تحدث هذه الحالة عند قيام أحد المستخدمين بعمل 


إجراءات الصيانة للبيانات والتي قد تتضمن إعادة فهرسة البيانات أو عمل مسu)ءه8B‏ للبيانات أو حذف قيود من 
جداول البيانات (٤ءه۴).‏ مما يتطلب التعامل مع البيانات بأسلوب منع بقية المستخدمين من التعامل مع البيانات 


في نفس الوقت. 


تنبيه: - عملية التداخل لا يمكن تجنبها عن طريق إهمال احتمالية حدوثهاء وذلك لأنه حتى بالنسبة لحاسبة منفردة 
غير مربوطة على شبكة حاسبات (إعءل عاع”81)ء فإن إمكانيات أنظمة التشغيل متعددة المهام ) Multi-1asks‏ 
(Operating systems‏ وبضمنها 0۷S‏ ل۷1٠‏ ومع وجود واجهات المستخدم llرس—وoة‏ ) Graphical User‏ 
٥ه‏ ا[) فإن المستخدم يستطيع تنفيذ التطبيق أكثر من مرةء أو تنفيذ عدة نماذج في نفس الوقت وقد تتعامل 
هذه النماذج مع نفس البيانات. 


ج . إستراتیجیات القفل في ۷۴٣۴‏ 
إذا قررنا أنه في وقت واحد يوجد فقط مستخدم واحد یمکنه تحدیث البیانات فإننا نستخدم ckم].‏ یقوم ۷۶۴۴۶۶ 
وبالتعاون مع نظام التشغيل من الاستجابة للقفل وفتح القفل على البيانات من التطبيق الذي يتم تنفيذه من قبل عدد من 
المستخدمين . 
يتم استخدام 0٥)18‏ لضمان التحديث الثابت للبيانات في القاعدةء وقد يكون القفل للجدول بأكمله (متثلا في حالة 
تغییر الھیکل (عإں† tru‏ yingگنلdمہ))‏ أو یکون القفل على قید (أو قیود) محدد ضمن الجدول. توفر ماکينة ۷۴۶ 
)۷۴۴P Database Engine)‏ ضمان عدم تحدیث البیانات من قبل آکثر من مستفید في نفس الوقت حتی ولو لم یتم 
استخدام .]0ck)1۸g‏ 


د . الأنواع الرئيسية لقفل البيانات 
من الأمور المتعارف عليها في أنظمة إدارة قواعد البيانات وجود ثلاثة أنواع من 2١i)ءم].‏ ويبين الجدول أدناه هذه 
الأنواع الثلاثة. 


[ 


نوع القفل ype‏ i«g)عم ‏ متوفرة في ۷۴۶ | مستخدم القفل بقية المستخدمين 


e O ET 
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XCIUSI1VE ۱‏ نعم نعم 
Shared ٢‏ کد نعم 
Update ۳‏ نعم نعم 


جدول يوضح أنواع ع« اعم[ في أنظمة إدارة قواعد البيانات 


ه .قفل قاعدة llبlgنlٽ Database Locking‏ 


عند فتح قاعدة البيانات في ۷۴۴ فإننا نفتحها بطريقتين فقط» إما نفتحها للاستخدام المتعدد أو نفتحها للاستخدام 
المفرد. ويعتبر هذا المستوى من القفل أعلى المستويات ولا يتم التفكير مطلقا في الاستخدام المتعدد إذا تم فتح قاعدة 
البيانات للاستخدام المفرد لأن هذا الأمر لا يمكن تحقيقه وقاعدة البيانات مفتوحة للاستخدام المفرد. وأي محاولة لتنفيذ 


التطبيق المفتوح للاستخدام المفرد أو استخدام إيعازات القفل تكون استجابة ۷۶۴۶ من 
تظھر فیھا عادö‏ عبار ة „(File Access Denied)‏ 
ويمكن فتح قاعدة البيانات من خلال الإيعازات التالية: - 
لفتح قاعدة البيانات للاستخدام المنفرد: - 
usiveاe×c‏ [اسم قاعدة 
لفتح قاعدة البيانات للاستخدام المتعدد: - 
shared‏ [اسم قاعدة 


لفقح قاعدة البيانات مع أخذ نوع الفتح من بيئة التطبيق أو :Set Exclusive jl Jڵlخ ja‏ - 
[اسم قاعدة البيانات]data open‏ 
فإذا كان الإيعاز المستخدم في الملف الرئيسي (١ه٠‏ عم۷وںاء×م مء) أو كانت البيئة هي 0٥١‏ 1۷eیںآا×8‏ فإن 
القاعدة تفتح للاستخدام المنفردء أما إذا كان الإيعاز المستخدم في الملف الرئيسي (fگه‏ ع۷إوںاء×م مء) أو كانت 


البيئة هي 0۴ ءون 8×1 فإن القاعدة تفتح للاستخدام المتعدد. 


Table Locking Jglدجئنl‎ Jû . و‎ 


إيعاز قفل الجدول يشبه إيعاز قفل قاعدة البيانات» فإذا أردنا فتح جدول للاستخدام المنفرد نستخدم الإيعاز التالي: - 


وفي هذه الحالة فإن بقية المستخدمين لا يستطيعون القراءة أو الكتابة إلى هذا الجدول. 
وإذا أردنا أن نفتح جدول للاستخدام المتعدد نستخدم الإيعاز التالي: - 


ز . قفل الجداول المفتوحة للاستخدام المتعدد 
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نعم کلا كلا 
کلا نعم کلا 
E‏ ر 


(Message) رة‎ Jالخ‎ 


open database [ٽlنlبلl‎ 


open database [ٽlنlبلl‎ 


uیع [اسم الجدول]‎ exclusive 


use [اسم الجدول]‎ shared 


جامعة الانبار - كلية الجحاسوب صديق قيس عبد الر من الدوسري 
حتى إذا فتحنا الجدول للاستخدام المتعدد فإننا نستطيع عمل )عم ماه لمل عليه من خلال استخدام الدالة «()Flock‏ 
أي أننا نسمح لمستخدم واحد (الذي يعمل )ع) من استخدام الجدول للتحديث وبقية المستخدمين يمكنهم القراءة من 
الجدول فقط. الدالة )ءه۴1() ترجع قيمة .1. في حالة نجاح القفل» وترجع .۴. في حالة كون الجدول مقفولا من قبل 
مستخدم آخر . ونستطيع فتح القفل من خلال إيعاز عهامدء أو إذا عملنا kعمامن‏ لأي قيد في الجدول المقفول. 
وهناك دالة أخرى يقترن عملها بهذا المجال وهي دالة عصهد عاطه)])dءkءم!؟ء]])‏ والتي ترجع .۲. إذا كان 
الجدول مقفولا ويرجع .۴. إذا كان الجدول غير مقفول. 
تنبيه: - إذا أر دنا فتح الجدول لعمل فعالييات الإدامة leيa «structure modifying «re-indexing)‏ 
)Packin8‏ فيجب فتح الجدول رآع۷ون!ء×ء لمنع بقية المستخدمين من القراءة من الملف أو الكتابة فيه. 
. قفل lالقيود‏ اmnlتJ Explicit Row Buffering‏ 
لا يمكن عمل ع1۷وںاء×ع لقيد ضمن جدول» إلا أنه يمكن فقط عمل )ء10 على القيد من خلال استخدام الدالة 
ڄء0() والدالة )ء1 )(۸R‏ والتي ترجع .1. في حالة كون القيد مقفولا وترجع .۴. في حالة كون القيد غير مقفول. 
والمثال التالي يوضح استخدام القفل: - 
SELECT 0‏ 
USE customer‏ 
Go top‏ 
IF !RLOCK()‏ 
LOCK ()‏ 


ENDIF 
UNLOCK IN customer 


کما ویوفر 7۴۶ إمكانية عمل قفل على عدد من القيود عن طريق استخدام الإيعاز: - 

Set multilocks on 
وتوجد دالة أخرى يقترن عملها بهذا الموضوع وهي دالة كع۸٥ء٥1٣١(() والتي ترجع .7. في حالة كون القيد‎ 
مقفولا وترجع .۴. في حالة كونه غير مقفول.‎ 


Implicit Row Bufferin 


یقوم 7۴۶ بعمل م٥٥1‏ ١٠هل‏ صن للقيود بصورة أوتوماتيكية دون تدخل مطور التطبيق» ويقوم بضمان عدم 
حدوث وجود أكثر من تحديث في نفس الوقت لبيانات مشتركة بين أكثر من مستخدم» ولفهم هذا القفل نأخذ مثالا في 
وجود مستخدمين تم دخولهم إلى نفس الجدول وهما يقفان على نفس القيد والجدول مفتوح للاستخدام المتعدد» فيمكن 
لهما تحديث القيد في نفس الوقت» إلا أنه في الحقيقة يقوم 7۶۶ من إجراء تحديث واحد فقط في نفس الوقت تماماء 
لذلك فإن قيمة الحقول المحدثة لهذا القيد ستكون القيم التي أدخلها المستفيد الذي تم قبول تحديثه كآخر التحديثات 


(التحديث من نصيب من يحدث أخيرا). 
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ي . كيفية الاستجابة في حالة عدم الحصول على 10٥K‏ 
في حالة محاولة عمل [10٥٣‏ على جدول أو قيود وفشل المحاولة لكون أن هناك مستخدم آخر عمل ×©10» فالذي 


يحدد عدد محاو لات عمل 10٥٣‏ هو إيعاز ئءئ٠عهإم#ع‏ ۴1ء حيث يتم تحديد عدد مرات المحاولة أو وقت 
المحاولة قبل ظهور عبارة الخطأ. والصيغة العامة لهذا الإيعاز هو: - 
Set Reprocess to [option]‏ 
وعبارة ٥ة‏ ٤صه‏ ممكن أن تكون أحد العبارات التالية: - 
عدد مرات تكرار محاولات القفل. 
وقت التكرار بالثواني. 


Row And Table Buffering Jودجئناi ك . حجز القيد وحجز‎ 

بالإضافة إلى ما تم ذكره من إيعازات (وهي إيعازات موجودة في الإصدارات السابقة أيضا) فإن ۷۴۶ يوفر 
إستراتيجيات جديدة وهي: - 

.Row and Table buffering 

.Transaction Processing 
#هعايخص الجداول المنفردة و‎ and taط1e‎ buffering الفرق بين الإستر اتيجيتين هي أن‎ 
يخص عدد من الجداول ضمن قاعدة البيانات.‎ tاعansact10n‎ Process 
هذه الإستراتيجيات غير متضاربة فيما بينهاء حيث توفر الأولى طريقة لحذف تحديثات المستخدم في حالة الجداول‎ 
المنفردة سواء كانت داخل القاعدة أو بشكل جداول حرة»ء والأخرى تضمن أن التحديثات لأكثر من جدول إما أن تقبل‎ 
للكل وإما أن ترفض للكل بشرط أن تكون كل الجداول ضمن قاعدة البيانات.‎ 
ويمكن النظر إلى الإستراتيجيتين على أنهما تحجز البيانات لأنها تقوم بإنشاء قيم رعة٣إهطصهغ للبيانات» ففي حالة‎ 
عع تهمل هذه القيم وتبقى بيانات جدول مثل‎ ٣٤ تجري التعديل للجدول من خلال هذه القيم وفي حالة‎ update 
. ما كانت‎ 


والجدول التالي يوضح مقارنة بين الإستراتيجيتين: - 


جدول يبين الفرق بين استراتيجيات الحجز 


Single Single Multiple Multiple 
free DB table free DB 
table tables tables 
Row Yes Yes No No 
&Table 
Transact No Yes No Yes 
ion 


Optimistic and Pessimistic Lockin 


SERAN 


صديق قيس عبد الرحمن الدو سري 
هد الرجه إلى انكام الححرء فان ار ار الاسامي الذي يحب اتخاده ,هي في اكام الخخز المت ايع 
ice buffering)‏ timistمpه)‏ أو الحجز المتشدد (وصمذإهu۴۴ط‏ icذ٤ءةصةكء٠ص)‏ والقرار الثاني 
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هو في حجز الجدول بأكمله أم في حجز قيد واحد فقط من الجدول. ماكينة قاعدة بيانات ۷/۴۶ ( Visua1‏ 
Database Engine‏ r0مpم×*٥۴)‏ يوفر نوعي الحجز» ومن الجدير بالذكر هنا أن الحجز هي ليست خاصية 
(رغ٤r٠مە٣إط)‏ تابعة إلى الجدول ضمن قاعدة البيانات» وإنما هي خاصية تابعة إلى الجدول عندما يكون مفتوحا 
ضمن ata Environment‏ داخل ”ع#٥۴.‏ ولذلك فإن الجدول يمكن حجزه في ۴٥m‏ بأکمله وفي 
۳ا٥۴‏ آخر نحجز فيه قید واحد فقط» أو قد نحجز الجدول حجز متسامح في ۴٥۳۳‏ وفي ۴٥۳۳‏ آخر نحجزہ 


حجز متشدد. 


Essentials of Optimistic Locking raluتall‎ Jفقلا اولا . أساسيات‎ 

في الحجز المتسامح (عذ٤ءذصة٤طه)‏ يتم تأجيل القفل (مء٥1)‏ لحين وقت إيعاز الموافقة على التحديث»› 
لذلك يمكن أن يقوم أكثر من مستخدم من تحديث نفس القيد في نفس الوقت. 

عندما یکون لدینا و٣1 row buffer‏ ptimisticeە‏ فإن 7۴۶ سیقوم بتحديث هذا القيد عند حركة 
مؤشر القيرد (إە ± nذەمط (record‏ أو عند غلق الجدول« أو عند تولید آڪعهjl «(()tableupdate‏ 
ففي هذه اللحظة فقط إذا حاول مستخدم آخر تحدیث هذا القید فسیولد ۷/۶۶ خطأ. 

وعندما یکون لدینا g٣ذ٣إه۴ timistiec غtaط1e bu‏ مه فإن التحديثات على البيانات سوف تؤجل 
إلى أن يقوم المستخدم بغلق الجدول أو استخدام إيعاز مخ هلم ں16طةع()ء وعندها یقوم 7۶۶ بعمل اختبار 
لكل قيد في الجدول» فإذا قام مستخدم آخر بتحديث ولو قيد واحد بعد بدء عملية الاختبار فإن ۷⁄۶۶ سيولد 
يعتبر pt ims tic row buffer ٣3‏ ذو فائدة كبيرة عندما يقوم المستخدم بتحديث الجدول 
بشكل قيد واحد في كل مرة» كما ويتيح لأكثر من مستخدم من تحديث نفس القيد» وأيضا فإن هذه الطريقة مفيدة 
لتقليل وقت القفل ولزيادة الكفاءة كما و تتيح هذه الطريقة لأكثر من مستخدم من تحديث مجموعة قيودفي 


جدول معین . 


ثانيا . أساسيات القفJ‏ ائnتiدد Essential of Pessimistic Locking‏ 
في و٣ذkء‌0ە1‏ ع1٤1"‏ ةعم فقط يوجد مستخدم واحد يقوم بتحديث القيد في نفس الوقت»› حيث يقوم 
row-level update Janaڊ VFP‏ أو update‏ e1ء1ev-1eطهaع‏ خلال فترة التحديث. وعند 
استخدام ور ذ10ck mist 1c row‏ sءم‌م‏ فسوف يقوم 7۶۶ وبصورة أوتوماتيكية بقفل القيد لحين 

حركة record pointer‏ أو استخدام إيعاز update‏ 1eطهkغ(()‏ أو إغلاق الجدول. 
كذلك فإن 7۶۶ يقوم بقفل كل القيود التي يقوم المستخدم بتحديثها لحين غلق الجدول أو استخدام 
date‏ 1eupطهغ()»‏ ولا يرى بقية المستخدمين التحديتات التي يقوم بها المستخدم لحين الانتهاء. 
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جامعة الانبار - كلية الحاسوب صديق قيس عبد الر من الدوسري 
تكون و٣ row buffer‏ imisticءesم‏ مفيدة عندما يقوم المستخدم بتحديث القيود في جدول بشكل قيد 
في كل مرة» وتکون البيانات حساسة جدا بحيث لا يسمح إلا لمستخدم واحد من تغييرها في نفس الوقت» ويمكن 


استخدام هذه الطريقة عندما يكون طول وقت القفل غير مهم أو يسمح النظام للمستخدم من قفل القيد لوقت غير 


محلل . 
تكرن و٣‏ 1٣٥uffط‏ 1eطta pessimistic‏ مفيدة بنفس خصائص وفوائّد pessimistic‏ 
›row buffering‏ إضافة إلى أن المستخدم يستطيع قفل أكثر من قيد في نفس الوقت أو قفل الجدول 
بأكمله. 


. الأحداث المتعارف 


هناك ثلاثة أحداث رئيسية في الاستخدام المتعدد قد تسبب تداخل بين المستخدمين وهذه الأحداث هي: - إضافة قيد 
(402)» تحدیث قید (70۶2۸7۳)» حذف قید »)0E1.E7۴(‏ وفيما يلي شرح لكل حالة عند استخدام 
:BUFFERING‏ - 


اولا . 402: - في حالة إضافة قيد جديد فإن التداخل لن يحدث أبدا إذا كان و”رذ٣٥۴۴ 8u‏ في حالة 
dع1طهn#‏ وذلك لأن القيد الجديد يتم حجزه ولا يظهر للمستخدمين الآخرين إلا إذا تم قبوله في الجدول. 


انيا . UP D47۴‏ - في حالة استخدام »1 Ù٤‏ ذصةكك٠ط‏ فإن التداخل لن يحدث أبداء ولكن عند استخدام 


timi sti‏ ص فقد يحدث تداخل عندما يحاول مستخدم معين تحديث وقبول تحديث قيد بينما هناك مستخدم 
آخر يقوم بتحديث نفس القيدء ففي هذه الحالة يسمح 7۴۶ في احتواء التداخل بالنسبة لتطبيق المستخدم الثاني 
وذلك من خلال شاشة استفسار حول رغبة المستخدم في الكتابة على تحديث المستخدم الآخر أو قبول تحديث 
ذلك المستخدم. 


ثاثا . 7# DEE‏ - هنا قد يحدث التداخل بطريقتين» الطريقة الأولى عندما يحاول مستخدمين حذف نفس القيد 
في نفس اللحظةء ففي هذه الحالة لا توجد مشكلة لأن كليهما يقومان بنفس العمل . والطريقة الثانية هي عندما 
يحاول مستخدم حذف قيد هو تحت تحديث مستخدم آخر . الأسلوب الأفضل لحل هذا التداخل هو جعل فعالية 
الحذف (أر رهغ٤uط‏ ٠٥1ء)‏ يقوم بتحسس فيما إذا كان القيد المراد حذفه هو تحت تحديث مستخدم 


Transaction Process. ù 
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حامعة ا = كلية ا ب 


ا عبد الر همر اللوي 


يعرف ٤ Database IEaNaSCEiOH‏ نه وحدة a‏ منطقية ) a Togical unit‏ 
„(work‏ يوفر 7۴۶ عملية ssئ٥ەProc‏ ansact10nا"‏ للسماح بتغطية كل تحديثات قاعدة البيانات معا 
ومعالجتها كوحدة عمل واحدة. بعدها يمكن قبول أو رفض كل التحديثات . 

۴۶ يسمح للمستخدم في تعریف Transaction jl Jîlخ ja transaction‏ Begin.وeند‏ 
تطبيق هذا الإيعاز فإن كل التحديتات على جداول قاعدة البيانات سوف تكتب في nمualږnمیى transacti0n‏ 
٣6ط‏ ولا تحدث البيانات في الجداول مباشرة. ولغرض إلغاء التحدیثات أو رفضها يمكن استخدام إيعاز 
معaط11٥R.‏ لتعود البيانات كما كانت (وذلك لأن البيانات موجودة في fer£ufظ .transact100‏ وفي 
حالة حدوث توقف في الحاسبة أو إطفائها مباشرة فإن عملية مهةط11٥ع‏ تحدث بصورة أوتوماتيكية. ولقبول 
التحديثات نستخدم End Transaction jl‏ . ومù‏ الجدير ڊiJlكر Y transaction process jİ‏ 
يطبق إلا على الجداول الموجودة في قاعدة البيانات فقط ولا يمكن أن تطبق على الجداول الحرة. 

VFP yè buffering عاوiأ ويبين الجدول التالي‎ 


Use 
To enable this 
value 
No buffering .The default value. 
Pessimistic record locks which lock record now, update when pointer moves or upon 
TABLEUPDATE(). 
Optimistic record locks which wait until pointer moves, and then lock and update. ۳ 


Pessimistic table locks which lock record now, update later upon TABLEUPDATE( ). 


Optimistic table lock which wait until TABLEUPDATE( ), and then lock and update 
edited records. 


تنبيه: - يجب عمل عم ]اانا في حالة 0١‏ عند استخدام أنواع £ buf ferin‏ من ۲ فما فوق . 


C[1aیيوعو الصنوف‎ . ١ 
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EDD DODD 000000 EDD 0000 E 
تعتبر الصنوف من أهم الأجزاء في لغات البرمجة بالكائنات الموجهة » فهي تعتبر القوالب الأساسية التي تصاغ منها‎ 


الكائنات في التطبيق . ويمكن النظر إلى مفهوم الصنوف من وجهة نظر أخرى ألا وهي اعتبارهانوع من أنواع 
البيانات غير التقليدية والمعقدة (وذلك لاحتوائها على العبارات البرمجية والبيانات و الإجراءات مع بعضها) فمن 


صديق قيس عبد الر حم الدو سري 
DS 0‏ 


معين على أنه متغير حرفي أو متغير رقمي ...الخ. وفي مفهوم التعامل مع الصنف كنوع بيانات يمكن تعريف أي كائن 
(مثل المتغير) ليكون من نفس الصنف الذي تم تعريفه تحته. 

يمكن استخدام الصنوف بطرق مختلفة. التخطيط الذكي يتيح للمستخدم معرفة الصنف المناسب لكل مهمة في التطبيق. 
ويمكن للمستخدم إنشاء صنف لكل 1٥إاصهء‏ أو لكل ۴٥۲٥١‏ يمكن ان يستخدمه» ولكن هذه الطريقة ليست هي الأفضل 
في بناء التطبيقات . حيث ستنتهي هذه الطريقة إلى مجموعة من الصنوف التي تؤدي نفس المهام تقريبا إلا أنه يجب 
إدامة وتحديث أو تغيير خصائص كل صنف على حدة. لذلك يمكن إنشاء صنوف لأداء مهام عامةء فمثلا يمكن إنشاء 
command button‏ یتیح للمستخدم الانتقال عبر قیود جدول معین ویمکن إضافة هذا ۸٥٥))ںuط‏ إلى أي form‏ لأداء 
هذه المهمة. 

كما ويمكن إنشاء وصإه؟ أو كاه٣٤«هء‏ ذات مواصفات وخصائص محددة واستخدامها في التطبيق حتى تظهر جميع 
عناصر التطبيق بصورة موحدة. فمثلا يمكن تحديد كعنطمهع أو ألوان معينة للنماذج أو المسيطرات التي يتم 
استخدامها في النماذج» أو مثلا إنشاء ×0ط)×ع) ذات مواصفات محددة من حيث نوع الحرف وحجمه واتجاه الكتاإبة 
والألوان واستخدامه في أي نموذج داخل التطبيق . 


أ . الصنوف الأساسية فı (Visual FoxPro Base Classes) VFP‏ 
يبين الجدول التالي الصنوف الرئيسية في ۷۴۴ والتي يمكن بناء صنوف ثانوية عن طريق هذه الصنوف الرئيسية 


وإضافتها إلى مكتبات الصنوف واستخدامها في التطبيقات . 
OLEBoundControl‏ 


جدول الصنوف الرئيسية في ۷۴۲ 


ملاحظة: - الصنوف المؤشرة بعلامة (*) في الجدول أعلاه يعني أن هذا الصنف هو مكمل للصنف الأب ولا يمكن 


ب . التوسع با الصنوف الرئيسية 
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صديق قيس عبد الر من الدوسري 
يمكن لاء صتوف ثادرية من الصترف الرئيس لوضع خصائضن بديهية لها :نماد ذا اردنا ان تجعل الأ امفيطر 
معين هو اسم نستخدمه في إنشاء النماذج الخاصة بنا فيمكن عمل ذلك من خلال إنشاء صنف جديد مبني على 
r1‏ ntدء‏ المطلوب بالاسم الذي نريده. وكذلك يمكن إنشاء صنف خاص إلى كص٣إإه]‏ من حيث المظهر والاتجاه 
والألوان ويكون هو القالب الذي يتم بناء جميع ۴٥۲"١‏ التطبيق عليه. كما ويمكن تحديد عمل المسيطر في الصنف 
لأداء عمل معين» فمثلا إذا أردنا أن نعمل ١٥اااط‏ Q١محمصسصهء‏ يستجيب لحدث معنا عليه بأن يغلق النموذج الذي 
يوضع فيه» فيمكن عمل ذلك عن طريق إنشاء صنف ثانوي مبني من الصنف الأب (١٥اااطا‏ d«جصصهء)‏ مع كتابة 
الإيعاز التالى فيه فى الحدث kعزاء:‏ - 

ThisForm.Release ٠ ٠ 
ويمكن توليد كائنات تابعة لهذا الصنف الجديد في أي نموذج» وسوف يودي هذا الكائن نفس العمل أينما وضع (وهي‎ 
هذا المثال.‎ )١- ١١( عملية إغلاق النموذج). ويوضح الشكل‎ 
عند إنشاء الصنوف الثانوية فليس بالضرورة أن يحتوي الصنف الجديد على مسيطر واحد ومن نوع واحد فقطء حيث‎ 
يمكن إضافة عدد من المسيطرات إلى الصنف الجديد وبأعداد مختلفة وحسب حاجة التطبيق . فمثلا إذا أردنا أن نعمل‎ 
صنف جديد يحتوي على العمليات التي يمكن أن تجري على جدول في نموذج معين فإننا سنضيف متلا عددا‎ 
من ؟١هااuط andصصدء يساوي عدد العمليات التي يمكن أن تحدث على الجدول.‎ 


Base class 
e EEE. 


Formîl EIB 


ا 


الشكل )٠- ١١(‏ مثال لإنشاء صنف انوي من صنف رئيسي 


Okject 


ج . إنشاءِ صنوف êڑıر‏ رأة Creating Non- Visual Classes‏ 
تعرف الصنوف غير المرئية على أنها الصنوف التي لا يوجد لها عنصر مرئي أشاء وقت التنفيذ (عصن مسم)ء 
ويمكن أن تكون مرئية فقط أثناء وقت التصميم (ع”ا «ع1وعل). فمثلا يمكن إنشاء صنف جديد وليكن اسمه 
StrMeth4s‏ يحتوي على عدد من الصيغ (ءلهطاءم.) الخاصة بالتعامل مع السلاسل الحرفية (sعمذعاء)»‏ فيمكن 
مثلا إضافة هذا الصنف إلى ٥۲٠١‏ يحتوي على ×0(لء ويمكن استدعاء الصيغ في هذا الصنف في أي وقت نشاءء 
فعلى سبيل المثال من الممكن أن يحتوي هذا الصنف على صيغة باسم 0)01 يقوم بحساب طول السلسلة 

الحرفية في ×0طلع وليكن اسمه i1لع»‏ فيمكن استدعائه بالصيغة التالية: - 
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وقت التنفيذء ويمكن تغيير خاصية eإں)ءم‏ لهذا الصنف إلى ملف من نوع (.م02) ليكون معروفا في وقت التنفيذ 
ويمكن تمييزه عن بقية الصنوف. 

د . إنشاء الصنوف 
يمكن إنشاء الصنوف من خلال استخدام مصمم الصنوف (١إ٥١ع1ومل‏ وهاء) وكما يلي: - 


من قائمة ما1٤‏ نختار سع1 ومن ثم نختار ككهاء. 


Llass Mame: [myclass 


Based Un: Control 3 Langel | 
Fram: 
Stare In: [myib. vex 3 


house the parent class from 
this drop-down lat. 


الشكل ١١(‏ -۲) شاشة إنشاء صنف جديد 


حيث يمثل مربع ع2۳ sءه1٣‏ اسم الصنف الذي نرغب في تسميته به. ويمثل مربع 0١‏ 4ء8 الصنف الرئيسي 
الذي نريد أن ننشأً الصنف الثانوي منه. ويمثل مربع 50۲١ 1١‏ اسم المكتبة التي نريد خزن الصنف الجديد فيه. 
وبعد تعريف اسم الصنف ومكتبة الخزن والصنف الأب واختيار 0 ستظهر لنا شاشة مصمم الصنوف ( ءيهإا٣‏ 
)Designer‏ كما موضح في الشکل (۱۱ -۳). 


E myelass-Click 


î Properties - mylib. vcs [my 
Emen I O oer EET 
34 Class Designer - mylib. vex [myclass] HEI EH 


E 


2| mpclass z 


| Data | Methods | Layout | Other 


ا 


ActiyeControl 


(Class Designer) شاشة مصمم الصنوف‎ )١- ١١( الشكل‎ 
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صديق قير ا ال 


ج مصمم E‏ نفس س النماذ» e‏ اسک ہن د تحدیث الخصائص من خلال نافذة 
الخصائص W(‏ ٥ہس‏ sع٤إممpہإP۴P)ء‏ کما ویسمح بكتابة الإيعازات للأحداث داخل نافذة التحديث ( عدنانلء 
.(window‏ 
ه . إضافة كائنات إلى Container Class gyi Class Control‏ 
إذا تم إنشاء الصنف الجديد من خلال صنف الأب الذي قد يكون 01إامهء أو إعمنهامهء» فيمكن إضافة sا0إ٤رco‏ 
له بنفس الطريقة كما في مصمم النماذج. وبغض النظر عن الصنف الأب فإنه يمكن تحديث الخصائص وكتابة 
الإيعازات للصيغ في هذا الصنف الجديد. 
كما ويمكن إضافة خصائص وصيغ جديدة للصنف الذي يتم إنشاؤه متل ما نرغب. حيث إن الخصائص تحمل قيم 
معينةء والصيغ يحمل إيعازات برمجية محددة يتم تنفيذها حين استدعاء الصيغة. 
ولإضافة خاصية جديدة للصنف نتبع ما يلي: - 
من lئnة .New Property رlتaخi Class‏ 
في مربع ۲۲٥٥۲۲۷‏ سء" نطبع اسم الخاصية. 
نحدد النو ع من خلالJ‏ اختيlر‏ Iئث: .Hidden gy «Protected «Public-‏ 
إذا كان النو ع ا۴ء فإن الخاصية يمكن تغييرها في أي مكان في التطبيق» أما بالنسبة إلى 4ع)ءع)ه]۲ و 
Hidden‏ فسیتم شرحھا لاحقا. 
ويبين الشكل )۱1 -6( ژlشة .New Property‏ 


Name: | لل‎ 
vib: ۸۹(Me | 


| Public 
Descriptiof Hidden 


الشكل )11 -6ئ( ژlشة New Property‏ 
ويمكن أيضا إدخال وصف للخاصية في الموقع المحدد ١10ام!إميمل.‏ 
ولإضافة 04ط]عط جديدة إلى الصنف الذي تم إنشاؤه نتبع ما يلي: - 
من lأئnة .New Method رlتخi Class‏ 
في شاشة 10ء سءN‏ نطبع اسم الصيغة. 
نحدد نو ع lنصيخغة (Hidden «Protected «Public)‏ 


نختار مربع Assign check box رiتخنو «Access method «lij Access check box‏ لإنشاء 
Access and Assign methods. assign method‏ تتيح للمستخدم معالجة العبارات البرمجية عندما يتم الاستفسار 


عن قيمة الخاصية أو عند تغيير قيمة هذه الخاصية. 
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و . حماية وإخفاء #ناصر llصiز Protecting and Hiding Class Members‏ 
الخصائص والصيغ في تعريف الصنف هي بديهيا من نوع ٬ناطں‏ ۴ء وهذا يعني أن العبارات البرمجية في صنوف 
أخرى أو ١ع‏ اع۴٠۴‏ معينة يمكنها تغيير خصائص الصنف أو استدعاء صيغه. إما في حالة لع)ءعاهإ۴ فإن 
الخصائص والصيغ يمكن معالجتها فقط من الصيغ الأخرى في تعريف الصنف أو من الصنوف الثانوية التابعة لهذا 
الصنف. وفي حالة ١ع‏ ل110 فإن الخصائص والصيغ يمكن معالجتها من قبل العناصر الأخرى في نفس الصنف فقط 

والصنوف الثانوية لا يمكن أن تعالج العناصر من نوع 1ع لل81. 
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نتناول هنا بعض المفاهيم المتقدمة في ۷۴۶ وبالأخص ربطه مع تطبيقات سه لم1 والمفهوم الأساسي للتطبيقات 
التي تسمى بربط قاعدة البيانات المفتوحة ( 008€ database connecti0o¬n‏ nعp٥)‏ كما ویتم التطرق إلى مفھوم 
تطبيقات الخادم و dlعميJ „(client-server Application)‏ 


نستطيع التوسع في التطبيقات التي يتم إنشاؤها في ۷۴۲ من خلال إدراج تطبيقات أخرى ضمن التطبيق المنشاً أو 
إضافة ما يسمى كاهإأصهء ×1۷8ا٥4.‏ ففي النماذج التي يتم تصميمها أو في الحقول داخل الجداول التي يكون نوع 
بياناتها عام (6۲41٠٠ع)‏ نستطيع إضافة النصوص» الأصوات» الصورء أو مقاطع الفيديو التي يتم جلبها أو ربطها من 
التطبيقات الأخرى الموجودة على الحاسبة. 


ب .1 تطبیق من نو ع ٥۴٤‏ 
من الممكن أن تكون كائنات الربط هي عميل (ءا١ء:1ء)‏ بالنسبة إلى ۷۴۴ كما ويمكن أن تكون هذه الكائنات هي 
الخادم (إ۲۷#م؟) إلى ۷۴۲ . العناصر التي تعمل كخادم تقدم كائنات (ءاءعزطه) إلى بقية العناصر» أما العناصر التي 
تعمل كعميل فإنها تستطيع إنشاء ءاءعزطه. 
من الممكن زيادة كفاءة التطبيق من خلال إدراج كائنات من تطبيقات أخرى مثل (1عء×٤» 0۲١‏ W....الخ).‏ 
يمكن ربط الكائن )11«K(‏ بالتطبيق أو احتضان الكائن (4ءطا٠ء)‏ بالنماذج أو بالجداول»ء فعلى سبيل المتال نستطيع 
ربط أو احتضان نص من ۷0۲۵ في حقل من نوع 16۲٥ع‏ في جدول معين» و ربط أو احتضان الكائن في 
النموذج. 
الفرق بين ع”iللع‏ اء وبين ع«i)«ذا‏ يقع في مكان خزن ه)هل. فالكائن المحتضن (لءللءط.ء) تخزن بياناته 
في الجدول أو النموذج» أما الكائن المربوط (4ءk)«ا)‏ فإن بياته تبقى في التطبيق الأب» وما يخزن في تطبیق ۷۴۲۶ 
هو فقط عنوان الوصول إليه. 


Formî Formz 
ا1 چ‎ Microzolt 
E Excel File 


ا[ ا 
ا 

Microsolt 

Excel File 

Embedded Ûata Linked Data 


الشكل (۱۲ )١-‏ مثال على كائن مربوط وكائن محتضن 
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| حامعة الانبار - كلية الحاسوب صديق قيس عبد الرحمن الدوسري 
REE EERE‏ 


ویبین الشكل (۱۲ وذ لورفا عمل من «Excel‏ مربوط ومحتضن ضمن نموذج في «Form 4aanul VFP‏ فإذا 
تم تغيير البيانات في ۴×٥1‏ فإن هذه التغيير سينعكس مباشرة على الكائن داخل النموذج. 


Bî li Excel - myoraph.xls E lal =× 
81 File Edt Wiew Inset Format Tools Data Window Help اھا‎ × 


اواك إل إعاد اعد افاعكلد لامك اواد 


HEE 


| [FFs Sheet SHeel2 7 SHEE A Sher 
Ready | Sum=U 


لا ټم که ص 
لا نم کک ص 


الشكل (۱۲ -۲) نموذج لكائن مربوط ومحتضن (linked and embedded)‏ 


بينما يوضح الشكل ٠۲(‏ -۳) نموذج لكائن محتضن فقطء وهذا الكائن هو عبارة عن ورقة عمل من 8×٥1‏ أيضا. 
في هذه الحالة إذا تم تغيير بيانات ورقة العمل في 1ءء×E‏ فإن التغيير سوف لن ينعكس في النموذج داخل التطبيق . 
وهذا المنطق يعكس صحة المفهوم الذي تم شرحه مسبقا وهو أن الكائن المحتضن داخل النموذج يتم خزن بياناته 
ضمن النموذج (أو في الجدول إذا تم إدراجه في حقل من نوع 1هإ#١ءع)ء‏ بينما في حالة الربط سيكون هناك فقط ما 
يشير إلى عنوان الكائن في التطبيق الرئيسي» لذلك فإن التغيير في بيانات الكائن في التطبيق الخادم سينعكس مباشرة 
في الكائن داخل التطبيق العميل. 


E E LT Ih ا= ادا‎ 
PIS 2l. o Lact Fao. aoa u ا#ادا ا1 نع‎ 


SELEEEHTEEEEEHBSEFFEEKS 
4ء اداه اد اس ا اراد > ا ت‎ 


DELE El م وا‎ 3 
TEY | Emri 


الشکل (۱۲ -۳) نموذج لكائن محتضن في نموڏج 
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صديق قير ا وري 


ج . إضافة كائن مريوط أو غير مربوط 
في أي نموذج أو تقرير» نستطيع إنشاء كاءعزطاه مرتبطة بحقل من نوع 66۲1ع في جدول معين»ء مثل هذه 
الکائنات تسمى s)ءeزا0 01٤‏ 0un4طء‏ ونستخدمھها لعرض محتویات ءاءعزاه 01۴ في حقل ۲۵1٤۸٣عع.‏ و لإنشاء 
OLE objects‏ undدط‏ نستخدم المسیطر 80۸4 ٤ا0‏ الموجود في ba۲ط01 .Form Controls ٥‏ ولإنشاء 
unbounded OLE‏ نستخدم المسیطر 0L۴ €0 1)a11٤۲‏ ومتل ھذا c٤‏ jط0‏ لا یر تبط مع genera] ۴e1‏ . 
نستطيع إضافة یاء‌زاه 01٤‏ إلى الجداول أو النماذج إما بصورة مباشرة أو برمجيا. 


د . إضافة و٤ءع‌زطه 0©1٤‏ إلى الجداول 
عند تصميم جداول قاعدة البيانات وظهور الحاجة إلى إدراج ءاءع‌ز ا0 0_۴ في الجداول» مثلا إذا كان لدينا جدول 
مواد في المخزن وأردنا إضافة نص ۷0۲4 يحتوي على شرح تفصيلي لكل نادة ومواصفاتها الفنية ...الخ. فيجب 
أو لا إضافة 1عا؟ 21إععع إلى الجدول ومن ثم إضافة 81۲ uءهل ۷0۲١‏ إلى الجدول إما بربطه بالحقل أو 
الختطنانة فيه 
و لإضافة ٤٥ء[‏ ا0 018 إلى جدول نتبع ما يلي: - 
في مصمم الجداول rabe Des¡ع "٤۲‏ ننشأً حقل من نو ع 8۵۸٤۲41‏ . 
نعمل 0wWseإاط‏ إلى الجدوJ .Modify General jlzgl gyİ general field ylJe Double Click Jai‏ 
من قائمة ٤di‏ نختار ectزط0b Insert‏ (أو iږتخدa .(Append Genral‏ 


. |عادة تiٿڍط Microsoft Graph‏ 
Microsoft Graph‏ هو کائن محتضن . والقیم في Microsoft Graph‏ مبنية علی اُساس القيم في ورقة البيانات 
فيه (٤٥عطء‏ هtهك).‏ كما في الشكل .)٤- ۱١(‏ 


3; Braph.msgraph Ila] 


اا ا ت ا ا ی ا ا یا ا ا ا ا ا ا ا ا 
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SIAN IIIIII 
ww o ټ‎ 
ډګ کد که ص‎ 
1 1 1 1 


icrosoft Graph ja جذومi‎ (°- ۱۲( الشكل‎ 


ولغرض تغيير البيانات برمجيا في طم6۲2» يجب إنشاء ع١5۲1‏ لغرض احتواء البيانات الجديدةء sطجا»‏ معcarriag‏ 
feeds «returns‏ 1[ineء‏ وتعبیر هذا ع«ا۲اء إلى طمaإع‏ من خلال مقطع ۸14( الموجود في الۈیےع—jl Append‏ 


. General 


ولتوضيح الفكرة نستخدم المثال التالي الذي نفترض فيه وجود جدول اسمه Kعهاء»‏ ومن ضمن حقوله حقل التاريخ 


وحقل سعر الإقفال (آخر سعر). الكائن ام62 ا؟soهإMic‏ مخزون في الحقل طم4إعءص (من نوع ۲21٥"عع)‏ في 
هذا الجدول. هذا المثال يعيد تنشيط طمه۲ع لبيانات آخر ثلاثين يوما. 


Comments 


Define carriage return and tab characters. 


Select the values that you want to update the graph with, 
in this case, the date and closing values for stocks for the 
last 30 days. 


Build a character string) LceData) of data from the cursor 


to refresh the graph. 
“Closing Price «as the column header, is the text that will 


be displayed by default in the graph ’s legend. 


Send the new values to the graph in the DATA clause of 
the APPEND GENERAL command. 


Close the cursor 


و لإضافة {٤ecزbاہ 0٥L۴‏ إلی ۴٥۲۳‏ نتبع ما یلي: - 


Code 
#DEFINE CRLF CHR(13)+CHR(0) 
#DEFINE TAB CHR(9) 
LOCAL IlcData 
SELECT date, close; 
FROM Stock WHERE BETWEEN(date, ; 
DATEQO,DATEOQO - 30) ; 
ORDER BY date INTO CURSOR wtemp 
SELECT wtemp 
IcData =" "+; 
TAB + "Closing Price" + CRLF 
SCAN 
IcData = IcData + DTOC (date) 
IcData = IcData + TAB 
IcData = IcData + ; 
ALLTRIM(STR(close)) + CRLF 
ENDSCAN 


SELECT graph 
APPEND GENERAL msgraph DATA IlcData 
USE IN wtemp 


من مصمم النماذج (form designer)‏ نختار 0LE Container‏ فيفتح مربع حواڙر .Insert Object‏ 


.)٥- ۱۲( كما في الشکل‎ »Create from fle أو‎ Create New رlتخi‎ Insert Object رly> من مربع‎ 


نختار ect‏ زه 0L۴‏ المناسب من قائمة 1st‏ ecز0b.‏ 


و لإضافة ٥LE€ 0bjec†‏ إلى rm controاs too1bar‏ نتبع ما بلي: - 
من قائمة ءامه نختار ك«هتام0. فتظهر لنا الشاشة كما في الشكل .)١- ٠١(‏ 


.ActiveX controls رlaخi‎ Controls tab ja 
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صديق قيس عبد الر حم الدوسري 
EE‏ 


fF Create Hew 
Internet Document [HTML] Lanzel | 


f Creale f Fil Media Clip 
EE Microsoft ClipArt Ballery 


Microsoft Data Map 

Microsoft Drawing 1.01 

Microsoft Excel Chart 

Microsoft Excel worksheet =| 


1” |nsert Control 
FT Display da leon 


Result 
lnzerts a new Bitmap Image’ object inka your 


ا 
document.‏ 


من قائمة 4ع)1ecع8‏ نختار OLE object‏ و Active× controls‏ المطلوب. 
الشکل (۱۲ )٥-‏ مربع Ûحوlر Insert Object‏ 


. 0K ومن تم‎ Set as Deu) نختار‎ 


من arطt001‏ sاcontro Form‏ نختار sع1asseا€ View‏ ومن ثم نختار .Ac)1۷e×‏ 


Regional | Debug | Syntax Coloring | Field Mapping | 


jey | General | Data | Remote Data | File Locations | Forms | Projects Controls 


¬ Wizual class libraries 
f 2ا‎ 


Selected: 


Shaw 
HY Insertable objects 
I# Controls 


Microsoft Cormrn Control 
Microsoft Data Map 
Microsoft Excel Chart 
Microsoft Excel worksheet 
Microsoft Graph 5.0 

Microsoft MÛPF| Message Control 
Microsoft MÃPl| Session Control 
Microsoft Multimedia Control 
Microsoft PowerPoint Presentation 
Microsoft PowerPoint 5 lide 


UURAAOUUOE 


Cancel | Help | Sel Az Datault | 
Options شاشة‎ )٦- ٠۲( الشكل‎ 


ولغرض عرض ۲٥ء‏ [ا0 0۴٤‏ من حقل من نو ع ۲21٥۸عت‏ نتبع ما یلي: - 
من ۴0m Designer‏ نضیف 80114 0٤‏ إلى النموذج. 


نحدد الحقل من نو ع ۲۵1٥١ء6‏ الذي يحتوي على البيانات عن طريق تغيير الخاصية ع .C0n)۲01801‏ 
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جامعة الانبار - كلية الجاسوب صديق قيس عبد الر من الدوسري 


فعلی سبیل المتال» إذا کان لدینا جدول اسمه ۷إ0ا 1۸۷٥1‏ وحقل 616۲41 فيه اسمه »۲۲۴٣٤‏ فنقوم بتغییر 
llخlصية .Inventory.current yll Contro1Source‏ 


کما ویمکن عرض ۲٥ء‏ [ط0 01٤‏ في النموذج برمجیا وکما يلي: - 


Code Comments 
frm] = CREATEOBJECT("form") Create form. 
frm1.ADDOBJECT("olb1", 
"oleboundcontrol") 
frm1.01b1.ControlSource = 
"Inventory.Current" 
frm1.olb1.Visible = .T. 
frm1.Visible = .T. 


Add control. 


Bind the data to the control. 


Make the control and form visible. 


هھ .ت تطبيقات lئخlدa Client/Server Applications‏ 

یوفر ۷۴۶ أدوات وإمکانيات تصميم تطبيقات ۲۷۵۲ع١/)1ء‏ 11ء قوية وكفوءة. تطبیقات ۵۲ ۵۲۷/٤"ieاc‏ في ۷۶۴۶۲ 
لكف خفاتضن افر الشركة و لجات السكك االر وة تقفار اة الف قازر + قات الل اة 
وأمنية المعلومات الداخلية. 
بناء تطبيق ١٥۲۷ع1/5ء11٣‏ عالي الكفاءة يتضمن الاستفادة من سرعة ماكينة ۷۴۴ . ويتم هذا من خلال تقنيات 
جديدة مثل »S81-84S8۲5 5۸۲۸ ۸٥۳۴88‏ و بناء استفسارات قياسية لجلب البيانات التي يحتاجها العميل من 
الخادم وليس كل القاعدةء وتوزيع جداول قاعدة البيانات بأوفق صورة ممكنة»ء وموازنة العمل بإجراءات 
(edue5تاP)‏ الموجودة عند العميل والإجراءات الموجودة عند الخادم. 
رل امخام ذه التشاك: ل بت من تضم القظام بشكل كن الاسقاةة الكاملة من اتح تليق هذه التق ات ولا 
بد من وضع إجابة للتساؤ لات التالية: - 

أي الجداول سيتم خزنها في ۷6۲٣ء‏ عن بناء التطبيق . 

أي الجداول ستكون ذات فائدة أكبر إذا تم خزنها في ٤٣عذاء‏ بشكل ءعاطة kupہ!.‏ 

أي المنظورات (sسء۷1)‏ سنحتاجها لمعالجة البيانات الموجودة في 56۲۷۵۲. 

أي من قواعد المعالجة للتطبيق سيتم تنفيذها من قبل ۲٠۲۷ء‏ وكيفية تقاطع العمل بين التطبيق على ١عناء‏ 
مع هذه القواعد. 


. إنشاء تطبيقات ائlëدoa Client/Server‏ 
يمكن لتطبيق ١٥۲۷ع۸1/5ء1ا٣‏ معالجة البيانات الموجودة في 5٥۲۷٥۲‏ عن طريق: - 
المنظورات البعيدö Remote Views‏ . 
.SQL pass-through‏ 
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يقة wsSعV1‏ ع0 Rem‏ أسهل طريقة جة وتحديث البیانات على ۲٥۲۷عS.‏ ب 
pass-through‏ (و هي أصعب نسبيا) إمكانية إرسال عبارات SQ‏ من ۲١نا‏ إلى إعم۷إم؟ مباشرةء ولكونها 
تعالج في See‏ ۴14-)ءه8B‏ فهي طريقة توفر السرعة والكفاءة في تطبيقات ١١ء۷إءم۸/5عا٣»‏ ويوضح الجدول 
التالي مقارنة بين طريقتي .SQL Pass-Through s Remote View‏ 


Remote View SQL Pass-Through 

Based on a SQL SELECT statement. Based on any native server SQL statement, enabling data 
definition statements or execution of server stored procedures. 
Can be used as data source for controls at 


design time. Cant be used as a data source for controls. 
Provides no ability to execute DDL 


ComEd oA. daf souréê Provides method for using DDL commands on data source. 
Fetches one result set. Fetches one or multiple result sets. 
Provides built-in connection management. | Requires explicit connection management. 


Provides built-in default update information 


for updates, inserts, and deletes. Provides no default update information. 


Provides implicit SQL execution and data 


fetching. Provides explicit SQL execution and result fetching control. 


Provides no transaction handling. Provides explicit transaction handling. 


Provides temporary properties for SQL pass-through cursor, 


Stores properties persistently in database. based on session properties. 


Employs asynchronous progressive 


fEtchine while Seoul SOL Fully supports programmatic asynchronous fetching. 


SQL Pass-Through yg Remote View jıڊ مقار‎ Jلودج‎ 


ز . مفھوم DAO‏ وھ ODBC‏ 
كائنات معالجة البيانات (04۸0) sاءeزbا0 ((Data Access‏ وربط قواعد البيانات ائمفتوضشة ) Open Database‏ 


Application Programing ) همها من نوع واجهات البرامج التطبيقية‎ ))€onnectivity (ODBC 
.)5D8MS( والتي توفر إمكانية التطبيقات بصورة مستقلة عن أي نظام إدارة قواعد بيانات‎ ء)!nter‎ faces) 41( 

يستخدم 40( إمكانيات Microsoft Jet Database Engine‏ لتوفير مجموعة من كائنات معالجة البيانات 
واي iتقضjan:‏ - Recordset objects «Querydef objects <‘Tabledef objects «Database objects‏ 


وغیرها. 

BC‏ يوفر ۸۴1 ها إمكانية توحيد عدد من أنظمة إدارة قواعد البيانات» من خلال استخدام 5إم91۷ 008٣٤‏ وجعلها تعمل كنظام واحد لإدارة قواعد البيانات. 
يقوم التطبیق باستخدام هذه ۸۴1 باستدعاء مدير D11۷‏ 008€ والذي يقوم بدوره بتعبير الاستدعاء إلى 5۲1۷٥‏ مناسب. ویقوم 5۲1۷6۲ بدوره بالاتصال مع 
858 باستخدام لغة الاستفسار المهيكلة (5Q1؟).‏ 
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